1、通过两边的指针,和中间值的比较决定向那一边进行递归比较
2、需要注意的点是,进行比较端点值时,需要单独考虑left和right指针重合的情况,否者将会导致查找两端值出现无法查找的情况
/*
二分查找
*/
import java.util.ArrayList;
import java.util.Arrays;
public class BinarySearchDemo {
public static void main(String[] args){
int[] arr = {1,8,10,89,89,1000,1234};
// System.out.println(binarySearch(arr,0,arr.length-1,1234));
for (int elem2:arr
) {
ArrayList<Integer> arrayList = binarySearch2(arr,0,arr.length-1,elem2);
if(arrayList.size()!=0){
for (Integer elem: arrayList
) {
System.out.println(elem);
}
}else{
System.out.println("无法查找到有效值!");
}
System.out.println("********************************* ");
}
/*
ArrayList<Integer> arrayList = binarySearch2(arr,0,arr.length-1,1234);
if(arrayList.size()!=0){
for (Integer elem: arrayList
) {
System.out.println(elem);
}
}else{
System.out.println("无法查找到有效值!");
}
System.out.println();
*/
}
// 二分查找的方法
public static int binarySearch(int[] arr,int left,int right,int findVal){
System.out.println("查找次数");
// 二分查找的方法
int mid = (left+right)/2;
int midVal = arr[mid];
if(left<right){
if(findVal > midVal){
// 向右递归
return binarySearch(arr,mid+1,right,findVal);
}else if(findVal < midVal){
return binarySearch(arr,left,mid-1,findVal);
}else{
return mid;
}
} else if (left == right) {
return mid;
}
return -1;
}
// 返回多个相同值的改进方法
public static ArrayList binarySearch2(int[] arr, int left, int right, int findVal){
// 二分查找的方法
int mid = (left+right)/2;
int midVal = arr[mid];
if(left==right){
if(midVal == findVal){
ArrayList arrayList = new ArrayList();
arrayList.add(mid);
return arrayList;
}
}
if(left<right){
if(findVal > midVal){
// 向右递归
return binarySearch2(arr,mid+1,right,findVal);
}else if(findVal < midVal){
return binarySearch2(arr,left,mid-1,findVal);
}else{
ArrayList<Integer> arrayList = new ArrayList<>();
int temp = mid-1;
while(true){
if(temp <0||arr[temp]!=findVal){
break;
}
// 将temp放入到arrayList
arrayList.add(temp--); // temp向左边移动
}
arrayList.add(mid);
temp = mid+1;
while(true){
if(temp>right ||arr[temp]!= findVal){
break;
}
arrayList.add(temp++);
}
return arrayList;
}
}
ArrayList arrayList = new ArrayList<>();
return arrayList;
}
}