二分查找算法速记

Posted 网管叨bi叨

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二分查找算法速记相关的知识,希望对你有一定的参考价值。

二分查找(英语:binary search),也称折半搜索(英语:half-interval search)对数搜索(英语:logarithmic search,是一种在有序数组中查找某一特定元素的搜索算法。搜索过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜索过程结束;如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。如果在某一步骤数组为空,则代表找不到。这种搜索算法每一次比较都使搜索范围缩小一半。

适合的场景:

  • Sorted(单调递增或者递减)

  • Bounded (存在上下界,因为要一分为二的进行查找)

  • Accessible by index(能够通过索引访问)

时间复杂度:

  • O(logN)

空间复杂度:

  • O(N) 使用常数空间,无论任何大小的输入数据,算法使用的空间都是一样的

适用的数据结构:

数组,因为在内存中时连续的适合使用二分查找。但是链表不适合,因为链表坐标不是固定的,访问a[2]需要先从a[0]的后继节点找到a[1]再通过a[1]的后继节点才能访问到a[2]。

步骤:

  1. 初始状态left、right 分别指向数组的头和尾。

  2. 通过(left + right) /2 得到中间位置mid,访问数组中mid位置的元素。

  3. 判断其与查找目标的大小关系,相等则程序返回,

  4. 比目标小则挪动left指针到mid + 1;比目标大则挪动right指针到mid - 1

  5. 重复上面步骤2 ~ 4直到找到目标元素或者程序退出。

代码实现:

 
   
   
 
  1. <?php


  2. $list = [1, 2, 5, 6, 8, 9, 12, 15, 23, 32, 56, 67, 73, 85];


  3. function biosearch($list, $target)

  4. {

  5. $left = 0;

  6. $right = count($list) - 1;

  7. while ($left <= $right) {

  8. $mid = ($left + $right) / 2;

  9. if ($list[$mid] == $target) {

  10. return true;

  11. } else if ($list[$mid] < $target) {

  12. $left = $mid + 1;

  13. continue;

  14. } else {

  15. $right = $mid - 1;

  16. continue;

  17. }

  18. }


  19. return false;

  20. }


参考文章:面试算法通关40讲,点击“阅读原文”即可订阅。

以上是关于二分查找算法速记的主要内容,如果未能解决你的问题,请参考以下文章

「算法笔记」一文摸秃二分查找

python算法:二分查找

java 二分查找法

二分查找算法讲解及其C++代码实现

leetcode查找算法(顺序查找,二分法,斐波那契查找,插值查找,分块查找)

二分查找算法