【算法】LeetCode『二分查找』

🎬 个人主页MSTcheng · CSDN
🌱 代码仓库MSTcheng · Gitee
🔥 精选专栏 : 《C语言
数据结构
《算法学习》
C++由浅入深

💬座右铭: 路虽远行则将至,事虽难做则必成!


前言:前面的文章中我们向大家介绍了滑动窗口算法,本篇文章就来介绍一下二分查找算法。

一、二分查找算法介绍

二分查找是一种在有序数组中快速定位目标值的算法。通过每次将搜索范围减半,其时间复杂度为 O(log n),效率远高于线性查找。

算法步骤:

初始化左右指针 leftright,分别指向数组起始和末尾。

计算中间索引 mid = left + (right - left) (避免整数溢出)。比较 arr[mid] 与目标值:

arr[mid] == target,返回 mid
arr[mid] < target,调整 left = mid + 1,继续搜索右半部分。
arr[mid] > target,调整 right = mid - 1,继续搜索左半部分。
重复上述过程直至 left > right,若未找到则返回 -1

由于二分算法的思路比较简单,这里直接给出具体的步骤,本篇文章讲的是最基础的二分算法,进阶的二分算法将会在后面介绍!

了解完了二分算法,下面来看题目:

二、二分查找

2.1题目展示

2.1题目示例

示例 1:

复制代码
输入: nums = [-1,0,3,5,9,12], target = 9
输出: 4
解释: 9 出现在 nums 中并且下标为 4

示例 2:

复制代码
输入: nums = [-1,0,3,5,9,12], target = 2
输出: -1
解释: 2 不存在 nums 中因此返回 -1

2.3题目解析

本题的题意非常简单,这里就不过多赘述。

2.4算法原理

2.5代码编写

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        //定义两个指针
        int left=0,right=nums.size()-1;
        int mid=0; 
        while(left<=right)
        {
            
            if(left!=0&&right!=0)
                mid=(left+right)/2;

            if(nums[mid]<target)
            {
                //小于往右边查找
                left=mid+1;
            }    
            else if(nums[mid]>target)
            {
                //大于往左边查找
                right=mid-1;
            }
            else//(nums[mid]==target)
            {
                return mid;
            }
        }

        return -1;

    }
};

三、总结

二分查找的朴素模板:

cpp 复制代码
while (left<= right)
{
	int mid =left + (right-left) /2;
	if(......)
		left =mid+1;
	else if(......)
		right = mid-1;
	else
	return......
}

二分查找的适用条件:

复制代码
数据必须为有序数组(升序或降序)。
仅适用于可通过索引随机访问的数据结构(如数组,不适用于链表)。
相关推荐
炽烈小老头2 小时前
【每天学习一点算法 2026/03/08】相交链表
学习·算法·链表
一碗白开水一2 小时前
【工具相关】OpenClaw 配置使用飞书:打造智能飞书助手全流程指南(亲测有效,放心享用)
人工智能·深度学习·算法·飞书
仰泳的熊猫3 小时前
题目2194:蓝桥杯2018年第九届真题-递增三元组
数据结构·c++·算法
Tisfy3 小时前
LeetCode 1888.使二进制字符串字符交替的最少反转次数:前缀和O(1)
算法·leetcode·字符串·题解
滴滴答滴答答4 小时前
机考刷题之 9 LeetCode 503 下一个更大元素 II
算法·leetcode·职场和发展
飞Link4 小时前
梯度下降的优化算法中,动量算法和指数加权平均的区别对比
人工智能·深度学习·算法
啊哦呃咦唔鱼4 小时前
LeetCode hot100-15 三数之和
数据结构·算法·leetcode
_日拱一卒4 小时前
LeetCode(力扣):杨辉三角||
算法·leetcode·职场和发展
rqtz4 小时前
基于I2C总线的IMU-磁力计融合算法与数据共享
算法·iic·espidf·qmc5883p·icm42670p·imu磁力计融合
leluckys4 小时前
算法-链表-二、成对交换两个节点
数据结构·算法·链表