二分查找

介绍

二分查找是一种在有序数组中查找某一特定元素的搜索算法。这种算法了解了会觉得很简单,但做题就非常容易出错,这篇文章是我整理的做题总结,如果你做题也迷迷糊糊 那可能会对你有帮助!

工作原理

你的目标是以最少的次数猜到这个数字。你每次猜测后,我会说小了、大了或对了。

方式有两种:

  1. 假设你从1开始依次往上猜,那目标值是57就一共猜了57次。
  2. 使用更聪明的方式,猜测过程会是这样。

小了,但排除了一半的数字!至此,你知道1~50都小了。接下来,你猜75。

大了,那余下的数字又排除了一半!使用二分查找时,你猜测的是中间的数字,从而每次都将余下的数字排除一半。接下来,你猜63(50和75中间的数字)。

这就是二分查找,你学习了第一种算法!恭喜你~

例子

ini 复制代码
(力扣35题)
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 O(log n) 的算法。

示例1:
输入: nums = [1,3,5,6,7,8,10,12], target = 5
输出: 2
完整代码:
var searchInsert = function(nums, target) {
    let left = 0   //设置查找区间
    let right = nums.length - 1
    let ans = nums.length
    while (left <= right) {
        let mid = Math.floor((left + right) / 2) //向上或向下取整都可以
        if( target <= nums[mid] ){
            ans = mid
            right = mid -1
        }else{
            left = mid + 1
        }
    }
    return ans
}

执行过程

设置左右边界,求出mid位置,5<target right需要移动

再次求出mid后,5并不小于target,left需要移动

再次求出mid后,5<=target,left没有重合依然在循环体里面 所以继续移动right

left和right重合这是循环体里的最后一次执行,返回mid

区间问题

上面的例子属于左闭有闭的区间

网上看了好多二分查找的模版如(左闭右开、左开右闭、左闭右闭、左开右开)。我个人觉得任何一种模版都不是万能的,逐个研究没有意义,选个一自己思考起来最顺手的就好,解决只能回到题目的场景去思考。

另外左右的边界地位是相等的 我暂时也不想到为什么要让其中一方取不到(狗头)

注意事项

在写二分查找时我们需要清楚

  • 循环可以继续的条件是什么
  • mid位置的值是否可能是问题的答案
  • 下一轮搜索想左还是向右
相关推荐
CoderCodingNo19 分钟前
【GESP】C++五级练习题 luogu-P1865 A % B Problem
开发语言·c++·算法
大闲在人30 分钟前
7. 供应链与制造过程术语:“周期时间”
算法·供应链管理·智能制造·工业工程
小熳芋33 分钟前
443. 压缩字符串-python-双指针
算法
Charlie_lll43 分钟前
力扣解题-移动零
后端·算法·leetcode
chaser&upper43 分钟前
矩阵革命:在 AtomGit 解码 CANN ops-nn 如何构建 AIGC 的“线性基石”
程序人生·算法
weixin_499771551 小时前
C++中的组合模式
开发语言·c++·算法
iAkuya1 小时前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼1 小时前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck1 小时前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆1 小时前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型