剑指offer 数组中重复的数字
Posted hiyashinsu
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer 数组中重复的数字相关的知识,希望对你有一定的参考价值。
代码
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即可。
第一次做题的时候可以试着去搞清里面的原理,但更重要的是思路和流程。做第二遍,第三遍......的时候就直接按照思路去解就好了,这是最行之有效的方式。
以上是关于剑指offer 数组中重复的数字的主要内容,如果未能解决你的问题,请参考以下文章