admin管理员组文章数量:1487745
LCR 173. 点名(二分)
一、题目描述
LCR 173. 点名
某班级 n 位同学的学号为 0 ~ n-1。点名结果记录于升序数组 records
。假定仅有一位同学缺席,请返回他的学号。
示例 1:
代码语言:javascript代码运行次数:0运行复制输入: records = [0,1,2,3,5]
输出: 4
示例 2:
代码语言:javascript代码运行次数:0运行复制输入: records = [0, 1, 2, 3, 4, 5, 6, 8]
输出: 7
二、题目解析
本题有多种解法:
但上述的解法的时间复杂度都是O(N),下面介绍O(logN)的最优二分解法。
本题的二段性比较难发现。
因为是有序的,并且是从0开始的有序数组,所以我们可以将数组分为两个部分,一部分就是数组的下标和数组本身的值相等,另一部分就是数组的下标要小于数组本身的值,这时我们要寻找丢失的值就是第二段的最小值!
注意细节问题:
注意特殊情况当数组完全是递增的情况下,会一直遍历到最后一个数据,但并不满足条件,因此在返回left的情况下,可以判断数组下标与相对应的值是否相等~
三、原码
代码语言:javascript代码运行次数:0运行复制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;
}
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2024-10-15,如有侵权请联系 cloudcommunity@tencent 删除intreturn遍历数据数组本文标签: LCR 173 点名(二分)
版权声明:本文标题:LCR 173. 点名(二分) 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/shuma/1754809755a3179860.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论