java二分搜索算法常见使用误区是什么
更新:HHH   时间:2023-1-7


这篇文章主要讲解了“java二分搜索算法常见使用误区是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java二分搜索算法常见使用误区是什么”吧!

直接使用二分搜索法,搜索一个无序的数组或集合。
 
如果你运气好的话,可能会搜索到你想要的数据,但是大部分情况下你不能得到你想要的结果。因为二分搜索是按照中间值来计算你要搜索数据的范围,每次逐渐缩小范围。如果你的结果不在一个按照升序排列的数组中,你要搜索的数据很可能被遗弃,然后返回负值。我们可以通过如下所示一段程序来断言,数组是否是有序的。
 
for(int i=0; i< arr.length; i++) {
    if(arr[i]>arr[i+1]) {
        return 0
    }
    return 1;
}
 

自己写了一个二分搜索算法,陷入了一个死循环,不知道为什么?


 因为你的边界没有完全控制好,所以造成了这种情况。如下:


反面教材 1:
数组 `int arr[] = {12,14,143,145,643,23453,233452};`
搜索数据 233452(直接陷入死循环)

int start = 0;
int end = arr.length-1;
while(start <= end) {
    int mid = (start + end) / 2;
    if(key < arr[mid]){
        end = mid;
    }else if(key > arr[mid]) {
        start = mid;
    }else {
        return mid;
    }
}
return -1;

如上这种写法看起貌似是正确的,如果仔细分析的话,会发现数组的长度为7

* 第一次循环中间量mid=3

* 第二次循环中间量mid=4

* 第三次循环中间量mid=5

* 第四次循环中间量mid=6

* 第五次循环中间量mid=6

* 第六次循环中间量mid=6

* 第七次循环中间量mid=6
* .....
* 由此陷入死循环

反面教材 2:
如果我们通过调试之后,把程序调整成如下,循环搜索结果,发现依然是个死循环。最终卡在了中间值5上,究其原因是因为,我们的中间值不能一直缩小,所以最终导致这个问题。

int start = 0;
int end = arr.length-1;
while(start <= end) {
    int mid = (start + end) / 2;
    if(key < arr[mid]){
        end = mid + 1;
    }else if(key > arr[mid]) {
        start = mid - 1;
    }else {
        return mid;
    }
}
return -1;


正确写法如下:(迭代过程中,循环不断减小。)


int start = 0;
int end = arr.length-1;
while(start <= end) {
    int mid = (start + end) / 2;
    if(key < arr[mid]){
        end = mid - 1;
    }else if(key > arr[mid]) {
        start = mid + 1;
    }else {
        return mid;
    }
}
return -1;

感谢各位的阅读,以上就是“java二分搜索算法常见使用误区是什么”的内容了,经过本文的学习后,相信大家对java二分搜索算法常见使用误区是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是天达云,小编将为大家推送更多相关知识点的文章,欢迎关注!

返回云计算教程...