剑指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 数组中重复的数字的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer1数组中重复的数字

剑指offer(二十六)之数组中重复的数字

剑指OFFER 数组中重复的数字

剑指 Offer 03. 数组中重复的数字 的 详细题解

剑指Offer 03. 数组中重复的数字

剑指Offer 03. 数组中重复的数字