二分查找
- 基本介绍
- 二分查找要求是查询一个有序数组
- 分递归和非递归查找
- 查找思路
- 首先确定数组中间的下标
mid = (left+right)/2 - 然后让需要查找的数findVal和arr[mid]比较
- if(findVal>arr[mid]){说明,要查找的数在mid的右边,因此需要向右递归查找}
- if(findVal<arr[mid]){说明,要查找的数在mid的左边,因此需要向左递归查找}
- if(findVal=arr[mid]){说明,要查找的数就是mid}
- 结束递归的条件
- 找到时结束递归
- 递归完整个数组仍然没有找到findVal,也需要结束递归==>>当left>right,就需要退出
- 代码演示——
package DataStructures.Search;
import java.util.ArrayList;
import java.util.List;
public class BinarySearch {
public static void main(String[] args) {
int arr[] = {1, 8, 10, 89, 1000,1000,1000,1000, 1234};
List<Integer> resIndexList = binarySearch2(arr,0,arr.length-1,1000);
System.out.println("resIndexList="+ resIndexList);
}
public static int binarySearch(int arr[], int left, int right, int findVal) {
if (left > right) {
return -1;
}
int mid = (left + right) / 2;
int midVal = arr[mid];
if (findVal > midVal) {
return binarySearch(arr, mid + 1, right, findVal);
} else if (findVal < midVal) {
return binarySearch(arr, left, mid - 1, findVal);
} else {
return mid;
}
}
public static List binarySearch2(int arr[], int left, int right, int findVal) {
if (left > right) {
return new ArrayList<Integer>();
}
int mid = (left + right) / 2;
int midVal = arr[mid];
if (findVal > midVal) {
return binarySearch2(arr, mid + 1, right, findVal);
} else if (findVal < midVal) {
return binarySearch2(arr, left, mid - 1, findVal);
} else {
List<Integer> resIndexList = new ArrayList<Integer>();
int temp = mid - 1;
while (true) {
if (temp < 0 || arr[temp] != findVal) {
break;
}
resIndexList.add(temp);
temp -= 1;
}
resIndexList.add(mid);
temp = mid + 1;
while (true) {
if (temp > arr.length - 1 || arr[temp] != findVal) {
break;
}
resIndexList.add(temp);
temp+=1;
}
return resIndexList;
}
}
}