import java.util.Arrays;
public class Code01_BSExist {
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);
int value = (int) ((maxValue + 1) * Math.random()) - (int) (maxValue * Math.random());
Arrays.sort(arr);
if(test(arr,value) != find(arr,value)) {
System.out.println("出错了!");
printArray(arr);
}
}
}
public static void printArray(int[] arr) {
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
public static Boolean test(int[] arr, int findValue) {
for (int i = 0; i < arr.length; i++) {
if(arr[i] == findValue) {
return true;
}
}
return false;
}
public static Boolean find(int[] arr, int findValue) {
if(arr == null || arr.length == 0) {
return false;
}
int L = 0;
int R = arr.length - 1;
while (L <= R){
int mid = (L+R)/2;
if(arr[mid] == findValue) {
return true;
} else if(arr[mid] < findValue) {
L = mid + 1;
} else if(arr[mid] > findValue) {
R = mid - 1;
}
}
return false;
}
public static int[] lenRandomValueRandom(int maxLen, int maxValue) {
int len = (int) (Math.random() * maxLen);
int[] arr = new int[len];
for (int i = 0; i < len; i++) {
int value = (int) (Math.random() * maxValue);
arr[i] = value;
}
return arr;
}
}