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

news/2024/10/6 21:53:50 标签: 算法, 学习, 数据结构, c++, 二叉树

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.实战代码

点名

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;
    }
};
寻找旋转排序数组中的最小值
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];
    }
};

http://www.niftyadmin.cn/n/5692199.html

相关文章

Linux驱动开发——新字符设备驱动开发

文章目录 1 概述2 新字符设备驱动原理2.1 分配和释放设备号2.2 新字符设备注册方法 3 自动创建设备节点3.1 mdev机制3.2 创建和删除类3.3 创建设备 4 设置文件私有数据5 实验程序编写 系列文章&#xff1a; Linux驱动开发——字符设备驱动开发 Linux驱动开发——LED驱动开发 1 …

wordpress运行环境 php版本过低提示及解决办法

如果你的wordpress网站上出现“Your server is running PHP version 5.6.40 but WordPress 6.6.2 requires at least 7.2.24.”&#xff0c;意思是“您的服务器运行的是PHP版本5.6.40&#xff0c;但WordPress 6.6.2至少需要7.2.24版本的”。这说明你wordpress网站运行环境有问题…

在 ArkTS 网络请求中,重新封装一下 http 模块

在ArkTS中&#xff0c;重新封装http模块可以提供一个更简洁、更易于使用的API&#xff0c;同时隐藏底层细节&#xff0c;使开发者能够更专注于业务逻辑。以下是一个简单的示例&#xff0c;展示了如何重新封装鸿蒙系统的kit.NetworkKit中的http模块&#xff1a; // 创建一个新的…

13:URL输入到页面渲染过程

从URL输入到页面渲染的过程是一个复杂而精细的流程&#xff0c;它涉及多个步骤和多个参与方&#xff08;包括浏览器、DNS服务器、服务器等&#xff09;。以下是这一过程的详细解析&#xff1a; 一、URL解析与DNS查找 URL解析&#xff1a; 当用户在浏览器中输入一个URL并按下回…

百度飞桨(paddlepaddle)安装

百度飞桨&#xff08;paddlepaddle&#xff09;安装 Anaconda升级 打开 Anaconda Prompt &#xff08;或者 Mac 下的终端&#xff09;&#xff0c;键入&#xff1a; conda upgrade --all pip 安装 python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/s…

C++——模板进阶、继承

文章目录 一、模板1. 非类型模板参数2. 模板的特化函数模板特化类模板特化1. 全特化2. 偏特化部分特化参数更进一步的限制 二、继承1. 概念2. 定义定义格式 3. 继承基类成员访问⽅式的变化4. 继承类模板5.基类和派⽣类间的转换6. 继承中的作⽤域隐藏规则&#xff1a; 7. 派⽣类…

物理学基础精解【55】

文章目录 函数函数及图形绝对值定义性质公式数学原理例题 区间定义性质公式数学原理例题 领域定义性质数学原理例题 绝对值的定理1. 绝对值的定义2. 非负性定理3. 绝对值的唯一性4. 相反数的绝对值相等5. 绝对值的乘法性质6. 绝对值的三角不等式&#xff08;或称为绝对值的加法…

【Python】数据可视化之聚类图

目录 clustermap 主要参数 参考实现 clustermap sns.clustermap是Seaborn库中用于创建聚类热图的函数&#xff0c;该函数能够将数据集中的样本按照相似性进行聚类&#xff0c;并将聚类结果以矩阵的形式展示出来。 sns.clustermap主要用于绘制聚类热图&#xff0c;该热图通…