首页 > 编程语言 > 详细

剑指offer 数组中重复的数字

时间:2019-10-06 09:49:34      阅读:133      评论:0      收藏:0      [点我收藏+]

代码

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 数组中重复的数字

原文:https://www.cnblogs.com/hiyashinsu/p/11626354.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!