【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 ==> 下一次相遇即为入口点,
相关推荐
颜酱21 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP2 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP2 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮2 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法