704.二分查找(力扣LeetCode)

704.二分查找(力扣LeetCode)

给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -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

提示:

  1. 你可以假设 nums 中的所有元素是不重复的。
  2. n 将在 [1, 10000]之间。
  3. nums 的每个元素都将在 [-9999, 9999]之间。

解题思路为二分算法,如果对二分算法不了解的可以看我这篇博客:二分算法(整数二分、浮点数二分)

cpp 复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        // 初始化左右指针
        int l = 0, r = nums.size() - 1;
        
        // 当左指针小于右指针时,执行循环
        while (l < r)
        {
            // 计算中间索引,这里使用位运算来求平均值
            int mid = l + r >> 1;
            
            // 如果中间的数大于等于目标值,则目标值在左半边,更新右指针
            if (nums[mid] >= target) r = mid;
            // 如果中间的数小于目标值,则目标值在右半边,更新左指针
            else l = mid + 1;
        }
        
        // 循环结束后,左指针会指向目标值或者是第一个大于目标值的元素
        // 检查左指针是否指向目标值
        if (nums[l] == target) return l;
        // 如果不是,则表示数组中没有目标值,返回-1
        else return -1;
    }
};
相关推荐
蜡笔小马19 小时前
10.Boost.Geometry R-tree 空间索引详解
开发语言·c++·算法·r-tree
我是咸鱼不闲呀19 小时前
力扣Hot100系列20(Java)——[动态规划]总结(下)( 单词拆分,最大递增子序列,乘积最大子数组 ,分割等和子集,最长有效括号)
java·leetcode·动态规划
唐梓航-求职中19 小时前
编程-技术-算法-leetcode-288. 单词的唯一缩写
算法·leetcode·c#
仟濹19 小时前
【算法打卡day3 | 2026-02-08 周日 | 算法: BFS】3_卡码网99_计数孤岛_BFS | 4_卡码网100_最大岛屿的面积DFS
算法·深度优先·宽度优先
Ll130452529819 小时前
Leetcode二叉树part4
算法·leetcode·职场和发展
颜酱19 小时前
二叉树遍历思维实战
javascript·后端·算法
宝贝儿好19 小时前
第二章: 图像处理基本操作
算法
小陈phd19 小时前
多模态大模型学习笔记(二)——机器学习十大经典算法:一张表看懂分类 / 回归 / 聚类 / 降维
学习·算法·机器学习
@––––––19 小时前
力扣hot100—系列4-贪心算法
算法·leetcode·贪心算法
CoovallyAIHub19 小时前
让本地知识引导AI追踪社区变迁,让AI真正理解社会现象
深度学习·算法·计算机视觉