【leetcode】287. 寻找重复数

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

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

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

示例 1:

输入:nums = [1,3,4,2,2]
输出:2

这一题的思路是 41. 缺失的第一个正数 + 142. 环形链表 Ⅱ,也就是安排每个数字应该在的位置,并把他们看成一个链表,最后找到链表的起始节点。

如果我们把 一个数字 x 放在 数组 index x de位置,那么多余的一个数字只能放在 index 0 的位置上,也就是说如果我们从 index 0 开始,找 index 0 这个位置上的数字应该放在哪里,然后以此类推,一定能够形成一个 当前 数组 value 代表当前链表节点指向 下一个 index 的 链表,并且这个链表一定是成环的。

举一个 [4, 4, 1, 2, 3] 的例子

最终会形成这样的一个链表,此时,我们再用 142 的 快慢指针去寻找 链表的起始节点即可,他的 index 就是 答案

class Solution {
    public int findDuplicate(int[] nums) {
        // 等价于 寻找循环节 前的一个节点
        int slow = 0;
        int fast = 0;
        do {
            slow = nums[slow];
            fast = nums[fast];
            fast = nums[fast];
        } while(slow != fast);

        fast = 0;
        while(slow != fast) {
            slow = nums[slow];
            fast = nums[fast];
        }
        return slow;
    }
}
相关推荐
浮生如梦_1 小时前
Halcon基于laws纹理特征的SVM分类
图像处理·人工智能·算法·支持向量机·计算机视觉·分类·视觉检测
励志成为嵌入式工程师3 小时前
c语言简单编程练习9
c语言·开发语言·算法·vim
师太,答应老衲吧3 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
捕鲸叉3 小时前
创建线程时传递参数给线程
开发语言·c++·算法
A charmer3 小时前
【C++】vector 类深度解析:探索动态数组的奥秘
开发语言·c++·算法
wheeldown4 小时前
【数据结构】选择排序
数据结构·算法·排序算法
观音山保我别报错5 小时前
C语言扫雷小游戏
c语言·开发语言·算法
TangKenny6 小时前
计算网络信号
java·算法·华为
景鹤6 小时前
【算法】递归+深搜:814.二叉树剪枝
算法
iiFrankie6 小时前
SCNU习题 总结与复习
算法