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

力扣 hot100 Day69

287. 寻找重复数

给定一个包含 n + 1 个整数的数组 nums ,其数字都在 [1, n] 范围内(包括 1 和 n),可知至少存在一个重复的整数。

假设 nums 只有 一个重复的整数 ,返回 这个重复的数 。

你设计的解决方案必须 不修改 数组 nums 且只用常量级 O(1) 的额外空间。

class Solution {
public:int findDuplicate(vector<int>& nums) {int slow = 0, fast = 0;do {slow = nums[slow];fast = nums[nums[fast]];} while (slow != fast);slow = 0;while (slow != fast) {slow = nums[slow];fast = nums[fast];}return slow;}
};

最优方法,将数组视为链表,重复值意味着有多个节点指向同一位置,即有环,问题转换为找环,之前刷过,具体思路如下。

  1. 将数组视为链表​​:将数组中的值视为指向下一个索引的指针。例如,nums[i]表示 i -> nums[i]。因为有重复的数字,所以至少有两个不同的索引会指向同一个位置,形成环。

  2. ​检测环的入口​​:使用快慢指针,快指针每次走两步,慢指针每次走一步,直到两者相遇。然后让一个指针从起点开始,另一个从相遇点开始,每次各走一步,再次相遇的点就是环的入口,即重复的数字

http://www.xdnf.cn/news/1264483.html

相关文章:

  • ISL9V3040D3ST-F085C一款安森美 ON生产的汽车点火IGBT模块,绝缘栅双极型晶体管ISL9V3040D3ST汽车点火电路中的线圈驱动器
  • P1044 [NOIP 2003 普及组] 栈
  • 项目一系列-第4章 在线接口文档 代码模板改造
  • day070-Jenkins自动化与部署java、前端代码
  • 深入解析K-means聚类:从原理到调优实战
  • 第七章:数据持久化 —— `chrome.storage` 的记忆魔法
  • Netty-Rest搭建笔记
  • 【感知机】感知机(perceptron)学习算法例题及详解
  • 在 Elasticsearch/Kibana (ELK Stack) 中搜索包含竖线 (|)​​ 这类特殊字符的日志消息 (msg 字段) ​确实需要转义
  • 基于LLM的Chat应用测试方法探索:系统化评估与持续优化
  • java分布式定时任务
  • B4263 [GESP202503 四级] 荒地开垦 题解
  • 操作系统:多线程模型(Multithreading Models)与超线程技术(Hyperthreading)
  • 飞算JavaAI深度解析:专为Java生态而生的智能引擎
  • YOLO-Count:用于文本到图像生成的可微分目标计数
  • C++中的继承:从基础到复杂
  • 【数据结构】排序(sort) -- 计数排序
  • Sum of Four Values(sorting and searching)
  • 文件管理从基础到高级:文件描述符、超大文件切片重组与快速删除实战
  • SVM实战:从线性可分到高维映射再到实战演练
  • 《在 Spring Boot 中安全使用 Qwen API-KEY:环境变量替代明文配置的最佳实践》
  • Word中怎样插入特殊符号
  • 智慧社区(九)——事务加持下的小区删除操作
  • Vue 路由跳转
  • 【JAVA EE初阶】多线程(进阶)
  • [案例十] NX二次开发批量替换组件功能(装配环境)
  • C 语言链表数据结构
  • 智驭全球波动:跨境量化交易系统2025解决方案
  • 嵌入式Linux学习 - 数据结构6
  • 机器学习——支持向量机(SVM)实战案例