剑指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即可。

第一次做题的时候可以试着去搞清里面的原理,但更重要的是思路和流程。做第二遍,第三遍......的时候就直接按照思路去解就好了,这是最行之有效的方式。

posted @ 2019-10-06 07:32  末夏始秋  阅读(118)  评论(0编辑  收藏  举报