[code]package com.heima.homework13;
public class Demo2_Array {
/**
* A:案例演示
* 数组高级二分查找代码
* B:注意事项
* 如果数组无序,就不能使用二分查找。
* 因为如果你排序了,但是你排序的时候已经改变了我最原始的元素索引。
*/
public static void main(String[] args) {
int[] arr = {11,22,33,44,55,66,77};
System.out.println(getIndex( arr, 33));
System.out.println(getIndex( arr, 55));
System.out.println(getIndex( arr, 88));
}
public static int getIndex(int[] arr,int value) {
int min = 0;
int max = arr.length - 1;
int mid = (min + max) / 2;
while(arr[mid] != value) {
if (arr[mid] < value) {
min = mid + 1;
}else if (arr[mid] > value) {
max = mid - 1;
}
mid = (min + max) / 2;
if (min > max) {
return -1;
}
}
return mid;
}
}
这个代码里面如果我要找55所对应的索引的话,那就是min = mid + 1;那就是min = 3 + 1 = 4; max = 6; mid = (min + max) / 2 = (4 + 6) / 2 = 5,那5所对应的数是66啊 不是我要找的55啊? 这是怎么回事啊? |
|