二分查找算法——寻找旋转排序数组中的最小值&点名

1.题目解析

题目来源:LCR173.点名------力扣

原名:剑指offer------0~n-1中消失的数字

测试用例

题目来源:153.寻找旋转排序数组中的最小值------力扣

测试用例

2.算法原理

点名

如果要寻找消失的数字,可以判断对应下标的数字是否和下标对应即可,根据这个定义可以将数据分为两段:规范段与不规范段

1.当mid指针落入不规范段,需要从右边缩小范围,因为mid可能直接指向结果,所以right只能更新到mid

2.当mid落入规范段,需要从左边缩小范围,可以将left直接更新为mid+1,不用担心遗漏数据

注意:如果缺少的是最后一个数字,需要特殊处理

细节:由于更新左右指针出现了mid+1,所以初始化mid时使用left+(right-left)/2即可,不用left+(right-left+1)/2,第二种使用的条件是更新左右指针出现mid-1
寻找旋转排序数组中的最小值

按照数组最后一个元素可以将数组分为两段,一段是大于最后一个元素的,另一段是小于最后一个元素的,即旋转上段与旋转下段

1.mid落入到旋转上段,说明最小值一定不在mid落入的一段,需要从左缩小范围,left可以更新为mid+1

2.mid落入旋转下段,说明最小值一定在mid落入的一段,需要从右边缩小范围,由于mid可能直接指向了结果,所以right只能更新到mid

细节:由于更新左右指针出现了mid+1,所以初始化mid时使用left+(right-left)/2即可,不用left+(right-left+1)/2,第二种使用的条件是更新左右指针出现mid-1

3.实战代码

点名

cpp 复制代码
class Solution {
public:
    int takeAttendance(vector<int>& records) 
    {
        int left = 0,right = records.size() - 1;
        while(left < right)
        {
            int mid = left + (right - left) / 2;
            //落入规范段
            if(records[mid] == mid)
            {
                left = mid + 1;
            }
            //落入不规范段
            else
            {
                right = mid;
            }
        }
        if(left == records[left])
        {
            return left + 1;
        }
        return left;
    }
};

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

cpp 复制代码
class Solution 
{
public:
    int findMin(vector<int>& nums) 
    {
        int left = 0,right = nums.size() - 1;
        while(left < right)
        {
            int mid = left + (right - left) / 2;
            //落入旋转上段
            if(nums[mid] > nums[nums.size() - 1])
            {
                left = mid + 1;
            }
            //落入旋转下段
            else
            {
                right = mid;
            }
        }

        return nums[left];
    }
};
相关推荐
落羽的落羽1 分钟前
【Linux系统】中断机制、用户态与内核态、虚拟地址与页表的本质
java·linux·服务器·c++·人工智能·算法·机器学习
bksczm2 分钟前
C++ iostream , sstream的基本理解
开发语言·c++
神工坊3 分钟前
技术分享︱多重参考系模型在风扇通风仿真中的自动化实现:精度与效率的工程平衡
算法·hpc·并行计算·cfd·cae·流体力学·风扇仿真
独断万古他化3 分钟前
【算法通关】递归:汉诺塔、合并链表、反转链表、两两交换、快速幂全解
数据结构·算法·链表·递归
冬夜戏雪7 小时前
实习面经摘录(九)
学习
arvin_xiaoting7 小时前
OpenClaw学习总结_I_核心架构_8:SessionPruning详解
前端·chrome·学习·系统架构·ai agent·openclaw·sessionpruning
前端摸鱼匠8 小时前
【AI大模型春招面试题11】什么是模型的“涌现能力”(Emergent Ability)?出现条件是什么?
人工智能·算法·ai·自然语言处理·面试·职场和发展
sqmw8 小时前
MFCMouseEffect:把桌面输入反馈这件事,做成一个真正可扩展的引擎
c++·插件·引擎·鼠标特效·键鼠指示·鼠标伴宠
MORE_778 小时前
leecode-合并区间-贪心算法
算法·贪心算法
沈阳信息学奥赛培训9 小时前
#undef 指令 (C/C++)
c语言·开发语言·c++