【Java】剑指Offer面试题三:在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数

题目描述

在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。
例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。
要求:时间复杂度 O(N),空间复杂度 O(1)。

解题思路(源自CyC大牛)

对于这种数组元素在 [0, n-1] 范围内的问题,可以将值为 i 的元素调整到第 i 个位置上进行求解。
以 (2, 3, 1, 0, 2, 5) 为例,遍历到位置 4 时,该位置上的数为 2,但是第 2 个位置上已经有一个 2 的值了,因此可以知道 2 重复。

代码实现:

public class Solution3 {
    /*时间复杂度为O(n),空间复杂度为O(1)。
     对于这种数组元素在 [0, n-1] 范围内的问题,可以将值为 i 的元素调整到第 i 个位置上进行求解。
    */
   // public static void main(String[] args) {

   //     int[] nums = new int[]{2, 3, 1, 0, 2, 5};
   //     int n = nums.length;
   //     int[] dup = new int[1];
   //     boolean flag = duplicate(nums, n, dup);
   //     System.out.println(flag + "," + dup[0]);
   // }

    public static void swap(int nums[], int m, int n) {

        int temp = nums[m];
        nums[m] = nums[n];
        nums[n] = temp;
    }

    public static boolean duplicate(int nums[], int length, int[] duplication) {

        if (nums == null || length <= 0) {
            return false;
        }

        for (int i = 0; i < nums.length; i++) {
            while (nums[i] != i) {
                if (nums[i] == nums[nums[i]]) {
                    duplication[0] = nums[i];
                    return true;
                }
                swap(nums, nums[i], i);
            }
        }
        return false;
    }
}

你可能感兴趣的:(剑指Offer)