题目描述
在一个长度为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;
}
}