leetcode二分查找

LeetCodehot100-34. 在排序数组中查找元素的第一个和最后一个位置

复制代码
class Solution {
public:
    int search(vector<int>& nums, int target){//>=
        int left=0,right=nums.size()-1;
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]<target) left=mid+1;
            else right=mid-1;
        }
        return left;
    }//[0, left-1] 中的所有元素都 < target
        //[right+1, n-1] 中的所有元素都 >= target
        //结束时 left = right + 1
    vector<int> searchRange(vector<int>& nums, int target) {
        int start=search(nums,target);
        if(start==nums.size()||nums[start]!=target) return {-1,-1};
        int end=search(nums,target+1)-1;//第一个 >= target+1 的位置,必然等于第一个 > target 的位置,
                                            //这个位置的前一个位置,就是最后一个 == target 的位置
        return {start,end};

    }
};

Leetcode162. 寻找峰值

复制代码
class Solution {
public:
    int findPeakElement(vector<int>& nums) {
        int left=0,right=nums.size()-2;//// 假设 nums.size() = 5,索引 0-4 right = 3
                                        // 循环中 mid 最大为 3
                                        // mid+1 最大为 4,安全 ✓
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]>nums[mid+1]) right=mid-1;//明下坡,峰值在左侧(包括 mid)
            else left=mid+1;//说明上坡,峰值在右侧
        }
        return left;
    }
};

Leetcode153. 寻找旋转排序数组中的最小值

复制代码
class Solution {
public:
    int findMin(vector<int>& nums) {
        int left=0,right=nums.size()-2;//// 假设 nums.size() = 5,索引 0-4 right = 3
                                        // 循环中 mid 最大为 3
                                        // mid+1 最大为 4,安全 ✓
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]>nums[nums.size()-1]) left=mid+1; //mid 在左半部分(较大的部分),最小值在右边
            else right=mid-1;// mid 在右半部分(较小的部分),最小值在左边(包括 mid)
        }
        return nums[left];
    }
};

Leetcode33. 搜索旋转排序数组

两次二分查找

复制代码
class Solution {
public:
    int search(vector<int>& nums, int target) {
        int left=0,right=nums.size()-1,sz=right;
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]>nums[sz]) left=mid+1;
            else right=mid-1;
        }//此时left指向最小值的地方
       if (target > nums[sz]) {
        // target 在左半区 [0, left-1]
        right = left - 1;
        left = 0;
    } else {
        // target 在右半区 [left, sz]
        right = sz;
    }
        while(left<=right){
            int mid=left+(right-left)/2;
            if(nums[mid]==target) return mid;
            else if(nums[mid]<target) left=mid+1;
            else right=mid-1;
        }
        return -1;
    }
};
相关推荐
郝学胜-神的一滴2 小时前
[ 力扣 1124 ] 解锁最长良好时段问题:前缀和+哈希表的优雅解法
java·开发语言·数据结构·python·算法·leetcode·散列表
戴西软件2 小时前
戴西CAxWorks.VPG车辆工程仿真软件|假人+座椅双调整 汽车仿真效率直接拉满
java·开发语言·人工智能·python·算法·ui·汽车
Tairitsu_H2 小时前
C++入门指南:从基础语法到核心特性全解析
c++·算法·基础
programhelp_2 小时前
2026 高盛(Goldman Sachs)Coding Interview 真题分享|Design HashMap + 其他面试题完整解析
算法·哈希算法
Pentane.2 小时前
力扣HOT100:T.1 两数之和|循环遍历算法笔记及打卡(12/100)
c++·笔记·算法·leetcode
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:士兵站队
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·士兵战队
无限进步_2 小时前
二叉树的中序遍历(非递归实现)
开发语言·数据结构·c++·windows·算法·visual studio
计算机安禾2 小时前
【数据结构与算法】第48篇:算法思想(三):贪心算法
c语言·开发语言·数据结构·算法·贪心算法·代理模式·图论
_深海凉_2 小时前
LeetCode热题100-爬楼梯
算法·leetcode·职场和发展