算法:5.在排序数组中查找元素的第⼀个和最后⼀个位置

34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode)

核心思路:二分查找

本题关键:

1.理解找左端点的二分查找算法

2.理解找右端点的二分查找算法

(请依次看解读内容)

思考一下,如果求右端点的判断指针移动方法不变,使用mid=left+(right-left)/2求右端点也是一样能求出来的。

java 复制代码
public int[] searchRange(int[] nums, int target){
        int[] indexes = new int[]{-1,-1};
        if(nums.length==0) return indexes;

        int left=0,right=nums.length-1;
        //找左端点-->使用int mid=left+(right-left)/2;
        while(left<right){
            int mid = left+(right-left)/2;
            int num = nums[mid];
            if(num<target) left=mid+1;
            else right=mid;
        }
        if(nums[left]==target) {
            indexes[0]=left;
           }else return indexes;
        left=0;
        right=nums.length-1;
        //找右端点-->使用int mid=left+(right-left+1)/2;
        while(left<right){
            int mid = left+(right-left+1)/2;
            int num = nums[mid];
            if(num<=target) left=mid;
            else right=mid-1;
        }
        if(nums[left]==target) indexes[1]=left;
        return indexes;
    }
相关推荐
8Qi82 分钟前
LeetCode 32:最长有效括号 —— 栈 + 标记法 题解
java·数据结构·算法·leetcode·职场和发展··括号匹配
机器学习之心4 分钟前
198种组合算法+优化CNN-LSTM+SHAP分析+新数据预测+多输出!深度学习可解释分析,强烈安利,粉丝必备
深度学习·算法·cnn-lstm·shap分析·198种组合算法
Tairitsu_H4 分钟前
[LC优选算法#3] 滑动窗口 | 将x减到0的最⼩操作数 | ⽔果成篮 | 字⺟异位词
c++·算法·leetcode·滑动窗口
bIo7lyA8v11 分钟前
算法复杂度与能耗关系的多变量分析研究的技术8
算法
洛水水40 分钟前
【力扣100题】76.搜索插入位置
数据结构·算法·leetcode
Techblog of HaoWANG44 分钟前
智巡守卫:多模态巡检智能体算法服务端设计与实现——基于Ollama+Qwen3.5的自动化巡检报告生成系统
运维·人工智能·算法·目标检测·自动化·边缘计算
小蒋学算法1 小时前
算法-灌溉花园的最少龙头数目-贪心
算法
满怀冰雪1 小时前
第07篇-差分算法-高效处理区间修改问题
数据结构·算法
KaMeidebaby1 小时前
卡梅德生物技术快报|重组蛋白的表达和纯化:工艺调试全记录:大肠杆菌体系重组蛋白的表达和纯化参数标定(肠激酶轻链案例)
前端·人工智能·算法·数据挖掘·数据分析
ZPC82101 小时前
如何将机械臂末端定位精度提升至微米如何进行标定
人工智能·算法·机器人