【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 ==> 下一次相遇即为入口点,
相关推荐
地平线开发者3 小时前
J6B vio scenario sample
算法
BothSavage15 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn15 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽16 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程