当前位置: 首页 > news >正文

LeetCode 540.有序数组中的单一元素

思路一:hash,键存入元素,值存入次数,然后遍历,不是最优解

思路二:二分查找

  • 假设数组为 [1, 1, 2, 2, 3, 4, 4],其中唯一出现一次的元素是 3
  • 在一个有序数组中,如果没有唯一的元素,那么对于每一对数字,成对元素的第一个数字一定出现在偶数索引上,第二个数字出现在奇数索引上。例如,1 的第一个出现位置在索引 0,第二个位置在索引 12 的第一个位置在 2,第二个位置在 3,依此类推
  • mid 是偶数时,我们可以比较 nums[mid]nums[mid + 1],如果它们相等,说明到 mid 为止都是成对出现的,因此唯一的元素在右半部分。
  • 如果 nums[mid]nums[mid + 1] 不相等,说明唯一的元素在左半部分,因为唯一的元素打破了成对出现的规律。
  • 在代码中,通过 if (mid % 2 == 1) mid--; 确保 mid 是偶数索引。如果 mid 是奇数,就将其减 1,使其变为偶数索引。
  • 这样我们可以始终确保 mid 是偶数索引,便于进行对比 nums[mid]nums[mid + 1],从而更有效地缩小查找范围。

http://www.lryc.cn/news/481391.html

相关文章:

  • 【图文】【DIY便签】如何自行编译OPENCV使用动态库
  • WordPress文章自动提交Bing搜索引擎:PHP推送脚本教程
  • C++题目分享
  • 【Spring 框架】初识 Spring
  • 链表(Linkedlist)
  • 信息安全工程师(79)网络安全测评概况
  • 保研考研机试攻略:python笔记(3)
  • 刘卫国MATLAB程序设计与应用课后答案PDF第三版
  • 【鉴权】Web 会话管理:Cookie、Session 和 Token 深度对比
  • ArkTS--应用状态
  • yolov8涨点系列之引入CBAM注意力机制
  • java标准JavaBean类
  • MATLAB界面设计全攻略:从基础入门到高级应用
  • JavaScript API部分知识点
  • 钉钉调试微应用整理2
  • C++初级入门(1)
  • group_concat配置影响程序出bug
  • 将Go项目编译为可执行文件(windows/linux)
  • IMS高压发生器维修高压电源维修XRG100/1000
  • 斯坦福泡茶机器人DexCap源码解析:涵盖收集数据、处理数据、模型训练三大阶段
  • RabbitMQ的DLX(Dead-Letter-Exchange 死信交换机,死信交换器,死信邮箱)(重要)
  • 【STM32F1】——舵机角度控制与TIM定时器
  • 想要成为独立游戏作者 :通关!游戏设计之道 2-1 HUD
  • sql专题 之 三大范式
  • node.js安装和配置教程
  • 定时器输入捕获实验配置
  • 【C/C++】memcpy函数的使用
  • spring-security(两种权限控制方式)
  • 【mongodb】数据库的安装及连接初始化简明手册
  • 【科普】卷积、卷积核、池化、激活函数、全连接分别是什么?有什么用?