中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java如何找出數組中重復的數字

發布時間:2021-06-23 15:04:15 來源:億速云 閱讀:528 作者:chen 欄目:編程語言

本篇內容主要講解“java如何找出數組中重復的數字”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“java如何找出數組中重復的數字”吧!

數組中重復的數字

找出數組中重復的數字。

在一個長度為 n 的數組 nums 里的所有數字都在 0~n-1 的范圍內。數組中某些數字是重復的,但不知道有幾個數字重復了,也不知道每個數字重復了幾次。請找出數組中任意一個重復的數字。 鏈接:https://leetcode-cn.com/problems/shu-zu-zhong-zhong-fu-de-shu-zi-lcof

示列:

輸入:
[2, 3, 1, 0, 2, 5, 3]
輸出:2 或 3

// 1 思路簡單:雙重循環,時間復雜度:O(n^2),空間占用少,但時間還可以優化【2353ms 46.1MB】

class Solution {
    public int findRepeatNumber(int[] nums) {
        int len = nums.length;
        for(int i=0;i<len;i++){
            for(int j=i+1;j<len;j++){
                if(nums[i] == nums[j]){
                    return nums[i];
                }
            }
        }
        return -1;
    }
}

// 2 HashMap保存出現的數字【10ms 47.3MB】

class Solution {
    public int findRepeatNumber(int[] nums) {
        int len = nums.length;
        Map<Integer,Integer> map = new HashMap<Integer,Integer>();
        for(int i=0;i<len;i++){
            if(map.containsKey(nums[i])){
                return nums[i];
            }
            map.put(nums[i],1);
        }
        return -1;
    }
}

// 3 數組長度為n,且數組元素的范圍在0 ~ n-1之間,在遍歷的過程中,將元素移動到對應的下標(while)【0ms 46MB】

class Solution {
    public int findRepeatNumber(int[] nums) {
        int len = nums.length;
        int temp;
        for(int i=0;i<len;i++){
            while(nums[i] != i){
                if(nums[i] == nums[nums[i]]){
                    return nums[i];
                } // 這塊代碼我開始是放在了交換語句下面,出錯了。當該位置的值歸為后就退出了程序【 nums[0] == nums[nums[0]] 】
                temp = nums[nums[i]];
                nums[nums[i]] = nums[i];
                nums[i] = temp;
            }
        }
        return -1;
    }
}

到此,相信大家對“java如何找出數組中重復的數字”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

彭阳县| 台中市| 周口市| 丹巴县| 大竹县| 吉木乃县| 六安市| 绍兴市| 汾阳市| 龙江县| 咸阳市| 龙井市| 太仓市| 安仁县| 扎鲁特旗| 克拉玛依市| 长顺县| 浙江省| 石泉县| 行唐县| 姜堰市| 廉江市| 琼结县| 读书| 阿巴嘎旗| 漯河市| 乡城县| 雷州市| 绥宁县| 浮梁县| 神池县| 浑源县| 八宿县| 靖西县| 呼玛县| 佛教| 怀集县| 怀安县| 肇庆市| 枣强县| 留坝县|