【LeetCode热题100(95/100)】寻找重复数

题目地址: 链接

环的入口: a

入口到相遇的点: b

环的步长: c

两个快慢指针公式:(a + b) * 2 = b + nc + a

变形可得,第一次相遇后,从起点走a步后可与慢指针相遇:nc - b = a

JS 复制代码
/*
 * @lc app=leetcode.cn id=287 lang=typescript
 *
 * [287] 寻找重复数
 */

// @lc code=start
function findDuplicate(nums: number[]): number {
    const n = nums.length;
    let [p, q] = [nums[0], nums[nums[0]]];
    while(p !== q) {
        p = nums[p];
        q = nums[nums[q]];
    }
    q = nums[0];
    p = nums[p];
    while(p !== q) {
        p = nums[p];
        q = nums[q];
    }
    return p;
};
// @lc code=end

// 1 - 2 - 3(a) - 4
//     └─------
// 到入口 a
// 入口到相遇的点 b
// 慢指针相遇的点 a + b = d
// 快指针相遇的点 a + b + nc = 2d
// nc = a + b
// nc - b(入口到b的距离) = a ==> 下一次相遇即为入口点,
相关推荐
吃好睡好便好1 天前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
仰泳之鹅1 天前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
x_yeyue1 天前
三角形数
笔记·算法·数论·组合数学
念何架构之路1 天前
Go语言加密算法
数据结构·算法·哈希算法
AI科技星1 天前
《数学公理体系·第三部·数术几何》(2026 年版)
c语言·开发语言·线性代数·算法·矩阵·量子计算·agi
失去的青春---夕阳下的奔跑1 天前
560. 和为 K 的子数组
数据结构·算法·leetcode
黎阳之光1 天前
黎阳之光:以视频孪生重构智慧医院信息化,打造高标项目核心竞争力
大数据·人工智能·物联网·算法·数字孪生
丷丩1 天前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_629494731 天前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
ʚ希希ɞ ྀ1 天前
单词拆分----dp
算法