劍指offer之數組中重複的數字(C++/Java雙重實現)

1.題目描述

找出數組中重複的數字。
在一個長度爲 n 的數組 nums 裏的所有數字都在 0~n-1 的範圍內。數組中某些數字是重複的,但不知道有幾個數字重複了,也不知道每個數字重複了幾次。請找出數組中任意一個重複的數字。
示例 1:
輸入:
[2, 3, 1, 0, 2, 5, 3]
輸出:2 或 3
限制:
2 <= n <= 100000

在這裏插入圖片描述

2.題目分析

博主有兩種解題思路
第一種原地置換法:如果沒有重複數字,那麼正常排序後,數字i應該在下標爲i的位置,所以思路是重頭掃描數組,遇到下標爲i的數字如果不是i的話,(假設爲m),那麼我們就拿與下標m的數字交換。在交換過程中,如果有重複的數字發生,那麼終止返回ture(這個方法比較刁鑽不容易想到博主會用C++實現)
第二種:利用Java中Set集合不能重複的特點,遍歷數組添加到集合,當add添加set集合中已有的元素時候返回false,以此作爲判斷是否有重複元素的條件

3代碼實現

3.1第一種方法的C++代碼

class Solution {
public:
    int findRepeatNumber(vector<int>& nums) {
         int temp;
        for(int i=0;i<nums.size();i++){
            while (nums[i]!=i){
                if(nums[i]==nums[nums[i]]){
                    return nums[i];
                }
                temp=nums[i];
                nums[i]=nums[temp];
                nums[temp]=temp;
            }
        }
        return -1;
    }
};

3.2第二種方法的Java代碼

class Solution {
    public int findRepeatNumber(int[] nums) {
        Set<Integer> set =new HashSet<>();
        for(int i=0;i<nums.length;i++)
        {    
            if(!set.add(nums[i]))
            {
                return nums[i];
            }
        }
        return -1;
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章