-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMinimumSort.java
More file actions
100 lines (72 loc) · 2.22 KB
/
MinimumSort.java
File metadata and controls
100 lines (72 loc) · 2.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
package edu.buffalo.liveramp;
public class MinimumSort {
public int minSort(int[] nums){
int i=0;
int j=nums.length-1;
while(i<nums.length-1 && nums[i]<=nums[i+1]){
i++;
}
while(j>0 && nums[j]>=nums[j-1])
j--;
int[] minmax= findMinMax(nums,i,j);
int minSearch = binaryMinSearch(nums,0,i-1,minmax[1]);
int maxSearch = binaryMaxSearch(nums,j+1,nums.length-1,minmax[0]);
//int maxSearch = maxSearch(nums,nums.length-1,j+1,minmax[0]);
//int minSearch = minSearch(nums,0,i-1,minmax[1]);
System.out.println("minsearch and axsearch == "+ minSearch + " "+ maxSearch);
return (maxSearch!=-1 ? maxSearch : j) - (minSearch!=-1 ? minSearch : i) + 1;
}
public int[] findMinMax(int[] nums , int start , int end){
System.out.println(start + " "+ end);
int max=Integer.MIN_VALUE;
int min =Integer.MAX_VALUE;
for(int i=start;i<=end;i++){
if(nums[i]>max)
max=nums[i];
if(nums[i]<min)
min=nums[i];
}
System.out.println(" max min - "+ max + " "+ min);
return new int[]{max,min};
}
/*public int minSearch(int[] nums,int start , int end ,int value){
for(int i=start;i<=end;i++){
if(nums[i]>value)
return i;
}
return -1;
}*/
public int binaryMinSearch(int[] nums , int start , int end , int value){
System.out.println("binary min value = "+ value);
while(start<end){
int mid = start + (end-start)/2;
if(nums[mid]<=value)
start=mid+1;
else
end=mid;
}
return nums[start]>value ? start : -1;
}
public int binaryMaxSearch(int[] nums , int start , int end , int value){
System.out.println("binary max value = "+ value);
while(start<end){
int mid = start + (end-start)/2;
if(nums[mid]<value)
start=mid+1;
else
end=mid;
}
return nums[start]>=value ? start-1 : -1;
}
/*public int maxSearch(int[] nums ,int start , int end,int value){
for(int i=start;i>=end;i--){
if(nums[i]<value)
return i;
}
return -1;
}*/
public static void main(String[] args) {
MinimumSort ms = new MinimumSort();
System.out.println(ms.minSort(new int[]{0, 1,6, 15, 25, 6,45, 7, 30, 40,45, 50}));
}
}