美文网首页
剑指Offer面试题 3 :数组中重复的数字

剑指Offer面试题 3 :数组中重复的数字

作者: 久仰96 | 来源:发表于2019-07-19 21:29 被阅读0次

题目

在一个长度为 n 的数组里的所有数字都在 0 到 n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字是重复的,也不知道每个数字重复几次。请找出数组中任意一个重复的数字。

Input:
{2, 3, 1, 0, 2, 5}

Output:
2

思路:

题目中的关键信息:

  1. 由于这个数组的长度为 n,而且里面所有的数字都在 0 到 n-1 的范围内。
  2. 只要求找出数组中任意一个重复的数字。

解法

我们有三种解法可以选择:

  1. 给数组进行排序,最好的时间复杂度就是O(nlogn)。
  2. 使用一个hashmap,只需要遍历一次添加到hashmap中,再以O(1)的时间复杂度拿到重复的数字。该算法时间复杂度为O(n),空间复杂度为:O(n)。
  3. 使用题目中给出的关键信息来做(原因:由于所有的数子都在0 到 n-1 范围内,也就是该数组中所有的数字都能用数组的下标来进行表示 ),让数组中每一个数字都放在和该数字相等的数组下标。时间复杂度为O(n),空间复杂度为O(1)。
    例如:

// 扫描数组,并把对应的数字和该数字相等的数组下标位置的数字进行交换。
{2,3,0,1,4,3} // 数组下标0,数字2,和数组下标为2的数字(0),判断不相等,则进行交换,否则直接返回该数字。
{0,3,2,1,4,3} // 数组下标0,数字0,相等。扫描下一个数,下一个数数组下标1,数字3,和数组下标为3的数字 (4) 进行判断,不相等则交换。
{0,4,2,1,3,3} // 数组下标还是为1,数字4,和数组下标4的数字 (3) 进行判断,不相等则交换
{0,3,2,1,3,4} // 数组下标还是1,数字3,和数组下标3的数字(3)进行判断,相等,直接返回该数字。

代码

public class solution{
  public int duplicate(int[] nums){
        // 这里可以问一下面试官,要直接抛出异常还是返回 -1 
        if(nums == null || nums.length <= 0){
            return -1;
        }
        for(int i = 0;i <nums.length;i++){
            //这里要使用while
            while(nums[i] != i){
                if(nums[i] == nums[nums[i]]){
                    return nums[i];
                }
                swap(nums,i,nums[i]);
            }
        }
        return -1;
    }
    private void swap(int[] nums,int i,int j){
        int t = nums[i];
        nums[i] = nums[j];
        nums[j] = t;
    }
}

相关文章

网友评论

      本文标题:剑指Offer面试题 3 :数组中重复的数字

      本文链接:https://www.haomeiwen.com/subject/otcelctx.html