public class Solution {
public boolean duplicate(int numbers[],int length,int [] duplication) {
duplication[0] = -1;
if (numbers == null) {
return false;
}
for (int i = 0; i < numbers.length; i++) {
while (numbers[i] != i) {
if (numbers[i] == numbers[numbers[i]]) {
duplication[0] = numbers[i];
return true;
}
swap(numbers, i, numbers[i]);
}
}
return false;
}
private void swap(int[] numbers, int a, int b) {
int tmp = numbers[a];
numbers[a] = numbers[b];
numbers[b] = tmp;
}
}
遍历数组
交换数组的第 i 个和第 arr[i] 个直到 i == arr[i]
如果出现两个不同位置的值相等,即arr[i] == arr[arr[i]] 说明重复
以工程师的思维去考虑问题,而不是科学家的。我们无需知道Why,而知道How即可。
第一次做题的时候可以试着去搞清里面的原理,但更重要的是思路和流程。做第二遍,第三遍......的时候就直接按照思路去解就好了,这是最行之有效的方式。
原文:https://www.cnblogs.com/hiyashinsu/p/11626354.html