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的情况下,可以判断数组下标与相对应的值是否相等~

三、原码

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;
    }
};

相关推荐

  1. 每日OJ题_算法_二分查找⑧_力扣LCR 173. 点名

    2024-01-20 08:26:04       56 阅读
  2. C/C++ 整数二分以及浮点数

    2024-01-20 08:26:04       72 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-20 08:26:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-20 08:26:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-01-20 08:26:04       87 阅读
  4. Python语言-面向对象

    2024-01-20 08:26:04       96 阅读

热门阅读

  1. 网页全屏html视频动画效果

    2024-01-20 08:26:04       51 阅读
  2. NGINX配置负载均衡算法

    2024-01-20 08:26:04       57 阅读
  3. leetcode课程表-207-拓扑排序

    2024-01-20 08:26:04       53 阅读
  4. 组件开发遇到的问题(vue的问题)

    2024-01-20 08:26:04       50 阅读
  5. [python]变量与常量

    2024-01-20 08:26:04       55 阅读
  6. CopyOnWriteArrayList介绍

    2024-01-20 08:26:04       47 阅读
  7. Flink的两阶段提交是什么

    2024-01-20 08:26:04       51 阅读
  8. 自己配置vue项目

    2024-01-20 08:26:04       53 阅读
  9. Spring AOP学习

    2024-01-20 08:26:04       39 阅读
  10. springboot如何创建全局线程池

    2024-01-20 08:26:04       53 阅读
  11. python入门,文件的编码,读取,写入,追加

    2024-01-20 08:26:04       60 阅读
  12. django 中group by 以及sum count

    2024-01-20 08:26:04       58 阅读
  13. Webpack5入门到原理13:开发服务器&自动化

    2024-01-20 08:26:04       60 阅读
  14. Linux 常用命令分享与示例

    2024-01-20 08:26:04       34 阅读