LeetCode-寻找重复数

133 阅读1分钟

算法记录

LeetCode 题目:

  给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间(包括 1 和 n),可知至少存在一个重复的整数。


说明

一、题目

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

二、分析

  • 乍一看一脸懵逼,不妨解析一下题意,说明整个数组只有一个重复点。
  • 不妨换个方向看一下,我们遍历的时候一旦遍历到这个点,之后的遍历将会是一个循环,因为很多次之后我还会遍历到一样值的一个点,这就有点像求解环的入口了。
  • 因此可以用快慢指针进行求解。
class Solution {
    public int findDuplicate(int[] nums) {
        int left = 0, right = 0;
        do{
            left = nums[left];
            right = nums[nums[right]];
        } while(left != right);
        left = 0;
        while(left != right) {
            left = nums[left];
            right = nums[right];
        }
        return left;
    }
}

总结

熟悉规律和快慢指针的使用。