LCR 173. 点名(二分)

一、题目描述

LCR 173. 点名

某班级 n 位同学的学号为 0 ~ n-1。点名结果记录于升序数组 records。假定仅有一位同学缺席,请返回他的学号。

示例 1:

复制代码
输入: records = [0,1,2,3,5]
输出: 4

示例 2:

复制代码
输入: records = [0, 1, 2, 3, 4, 5, 6, 8]
输出: 7

二、题目解析

本题有多种解法:

但上述的解法的时间复杂度都是O(N),下面介绍O(logN)的最优二分解法。

本题的二段性比较难发现。

因为是有序的,并且是从0开始的有序数组,所以我们可以将数组分为两个部分,一部分就是数组的下标和数组本身的值相等,另一部分就是数组的下标要小于数组本身的值,这时我们要寻找丢失的值就是第二段的最小值!

注意细节问题:

注意特殊情况当数组完全是递增的情况下,会一直遍历到最后一个数据,但并不满足条件,因此在返回left的情况下,可以判断数组下标与相对应的值是否相等~

三、原码

cpp 复制代码
class Solution {
public:
    int takeAttendance(vector<int>& records) {
        int left = 0;
        int right = records.size()-1;
        int mid = 0;
        while(left < right)
        {
            int mid = left + (right - left)/2;
            //判断二段性,看下标的值和下标对应数组的值是否相等
            if(records[mid] == mid)
                left = mid+1;
            else
                right = mid;
        }  
        //细节处理,看是否是完全递增
        if(records[left] == left)
            return left + 1;
        return left;
    }
};
相关推荐
山楂树の44 分钟前
买卖股票的最佳时机(动态规划)
算法·动态规划
小O的算法实验室1 小时前
2024年IEEE TMC SCI1区TOP,面向无人机辅助 MEC 系统的轨迹规划与任务卸载的双蚁群算法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
无才顽石2 小时前
什么是数学
算法·数理象
CoderCodingNo2 小时前
【GESP】C++五级真题(数论, 贪心思想考点) luogu-B4070 [GESP202412 五级] 奇妙数字
开发语言·c++·算法
百***58842 小时前
MATLAB高效算法实战技术文章大纲1
人工智能·算法·matlab
hans汉斯3 小时前
【人工智能与机器人研究】自动移液设备多轴运动控制系统设计
算法·机器学习·3d·自然语言处理·机器人·硬件架构·汉斯出版社
guygg883 小时前
经典信道估计MATLAB实现(含LSMMSE算法)
深度学习·算法·matlab
foundbug9993 小时前
最小二乘支持向量机(LSSVM)回归的解析
算法·支持向量机·回归
程芯带你刷C语言简单算法题4 小时前
Day43~实现一个算法求一个数字的树根
c语言·开发语言·算法·c
柳鲲鹏4 小时前
关于#pragma pack(push, 8),DeepSeek回答错误
算法