[优选算法专题三.二分查找——NO.24搜索旋转排序数组中的最⼩值]

题目链接

LCR 173. 点名

题目描述

题目解答

代码的核心思路是使用二分查找法,时间复杂度为 O (log n),空间复杂度为 O (1),

代码解析:

  1. 函数takeAttendance接收一个记录数组records,返回缺失的学生编号。

  2. 二分查找的逻辑:

    • 定义左右指针leftright
    • left < right时,计算中间位置mid
    • 如果records[mid] == mid,说明在mid位置之前的学生都已正常出席,缺失的学生在右侧,因此移动leftmid + 1
    • 否则,说明缺失的学生在左侧或就是mid位置,因此移动rightmid
  3. 循环结束后:

    • 如果records[left] == left,说明所有学生都已出席,缺失的是最后一个学生的下一个编号(left + 1
    • 否则,left所在位置就是缺失的学生编号

这个算法的前提假设是:数组中除了一个缺失的编号外,其他编号都是连续且与索引位置一致的。例如,对于数组[0,1,2,4,5],算法会正确返回3

相关推荐
TracyCoder12329 分钟前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
We་ct2 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
小妖6662 小时前
js 实现快速排序算法
数据结构·算法·排序算法
xsyaaaan2 小时前
代码随想录Day30动态规划:背包问题二维_背包问题一维_416分割等和子集
算法·动态规划
独好紫罗兰5 小时前
对python的再认识-基于数据结构进行-a003-列表-排序
开发语言·数据结构·python
wuhen_n5 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
努力学算法的蒟蒻5 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495645 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
独好紫罗兰5 小时前
对python的再认识-基于数据结构进行-a002-列表-列表推导式
开发语言·数据结构·python
2401_841495645 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归