二分法查找
算法:二分法查找适用于数据量较大时,但是数据需要先排好顺序。主要思想是:(设查找的数组区间为array[low, high])
(1)确定该区间的中间位置K(2)将查找的值T与array[k]比较。若相等,查找成功返回此位置;否则确定新的查找区域,继续二分查找。区域确定如下:a.array[k]>T 由数组的有序性可知array[k,k+1,……,high]>T;故新的区间为array[low,……,K-1]b.array[k]<T 类似上面查找区间为array[k+1,……,high]。每一次查找与中间值比较,可以确定是否查找成功,不成功当前查找区间将缩小一半,递归查找即可。时间复杂度为:O(log2n)。
主要思路,讲一个有序的数组,中间分一半进行判断与中间数的大小关系,然后再进行拆分判断,知道找到这个数
int[] arr = {1,2,3,4,5,6,7,8,9,10};
我们 随机生成一个数,假设是8
我们先进行第一轮判断
最低的索low引为0,最高的索引high为9 ,
中间的索引mid为 (0 + 9) / 2 —> 4
如果8 > arr[4] 就在 arr[4] ~ arr[9] 之间去寻找
如果8 < arr[4] 就在 arr[0] ~ arr[4] 之间去寻找
如果8 = arr[4] 就是 arr[4]
下面我们来写代码
测试结果
8的索引为7,结果正确
若有出错,还望指正,共勉