1 二分查找法思想
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/d1b7c9c578af81852492bedb06288984.png)
2 二分查找法的代码实现
package search;
import java.util.Arrays;
public class BinarySearchForJava {
public static void main(String[] args) {
int arr[] = { 1, 8, 10, 89,1000,1000, 1234 };
int findVal = 8;
int index = binarySearch(arr,0,arr.length - 1, findVal);
System.out.print("查询的数组为: ");
show(arr);
System.out.println("查询的数为: " + findVal);
System.out.println("查询的位置为: " + index);
}
public static int binarySearch(int[] arr, int left, int right, int findVal) {
if(left > right || findVal < arr[0] || findVal > arr[arr.length - 1]){
return -1;
}
int mid = (left + right) / 2;
int midVal = arr[mid];
if(midVal > findVal){
return binarySearch(arr, left, mid - 1, findVal);
} else if (midVal < findVal) {
return binarySearch(arr, mid + 1, right, findVal);
}else {
return mid;
}
}
public static void show(int[] arr) {
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
System.out.println();
}
}