/**
* 局部最小值问题 已知一个无序数组,相邻两个数不相等,寻找一个局部最小值(如果0位置的数比1位置的数小,
* 则0位置的数就是最小值,如果N-1位置的数比N-2位置的数小,则N-1位置的数就是最小值,除此之外,寻找一个即小于左边,
* 又小于右边的数,我们则认为它局部最小值)
*
*/
public class Code04_BSAwesome {
public static void main(String[] args) {
int maxLen = 50;
int maxValue = 100;
int testTime = 100000;
for (int i = 0; i < testTime; i++) {
int[] arr = lenRandomValueRandom(maxLen, maxValue);
try {
int index = find(arr);
if(test(arr,index) != index) {
System.out.println("出错了!");
printArray(arr);
System.out.println();
}
}catch (Exception e){
printArray(arr);
break;
}
}
}
private static int test(int[] arr, int index) {
if(arr == null || arr.length == 0) {
return -1;
}
int N = arr.length;
if(N == 1) {
return 0;
}
if(arr[0] < arr[1]) {
return 0;
}
if(arr[N-1] < arr[N - 2]) {
return N-1;
}
if(arr[index] < arr[index-1] && arr[index] < arr[index+1]) {
return index;
}
return -1;
}
public static void printArray(int[] arr) {
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
public static int find(int[] arr) {
if(arr == null || arr.length == 0) {
return -1;
}
int N = arr.length;
if(arr.length == 1) {
return 0;
}
if(arr[0] < arr[1]) {
return 0;
}
if(arr[N-1] < arr[N - 2]) {
return N-1;
}
int L = 0;
int R = arr.length - 1;
int t = -1;
while (L < R - 1){
int mid = (L+R)/2;
if(arr[mid] < arr[mid-1] && arr[mid] < arr[mid+1]) {
return mid;
} else if(arr[mid] > arr[mid - 1]){
R = mid - 1;
} else if(arr[mid] > arr[mid + 1]){
L = mid + 1;
}
}
return arr[L] < arr[R] ? L : R;
}
// 返回一个数组arr,arr长度[0,maxLen-1],arr中的每个值[0,maxValue-1]
public static int[] lenRandomValueRandom(int maxLen, int maxValue) {
int len = (int) (Math.random() * maxLen);
int[] arr = new int[len];
if(len == 0) {
return arr;
}
arr[0] = (int) (Math.random() * maxValue);
for (int i = 1; i < len; i++) {
int value = (int) (Math.random() * maxValue);
while (value == arr[i-1]){
value = (int) (Math.random() * maxValue);
}
arr[i] = value;
}
return arr;
}
}
算法基础之二分查找之四
最新推荐文章于 2024-07-25 23:26:35 发布