成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

leetcode442. Find All Duplicates in an Array

yimo / 3349人閱讀

摘要:題目要求存在一個(gè)整數(shù)數(shù)組,其中的所有元素都位于之間,其中是數(shù)組的長(zhǎng)度。有的元素出現(xiàn)了一次,而有的元素出現(xiàn)了兩次。思路一交換為了在的時(shí)間內(nèi)找到所有的出現(xiàn)兩次的數(shù)字,其核心要求在于用現(xiàn)有的數(shù)組記錄已經(jīng)訪問(wèn)過(guò)的元素,同時(shí)不會(huì)丟失尚未訪問(wèn)過(guò)的元素。

題目要求
Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once.

Find all the elements that appear twice in this array.

Could you do it without extra space and in O(n) runtime?

Example:
Input:
[4,3,2,7,8,2,3,1]

Output:
[2,3]

存在一個(gè)整數(shù)數(shù)組,其中的所有元素都位于1~n之間,其中n是數(shù)組的長(zhǎng)度。有的元素出現(xiàn)了一次,而有的元素出現(xiàn)了兩次。找到數(shù)組中所有出現(xiàn)兩次的數(shù)字。

思路一:交換

為了在O(N)的時(shí)間內(nèi)找到所有的出現(xiàn)兩次的數(shù)字,其核心要求在于用現(xiàn)有的數(shù)組記錄已經(jīng)訪問(wèn)過(guò)的元素,同時(shí)不會(huì)丟失尚未訪問(wèn)過(guò)的元素。思路一采用交換的核心思想,即每次都將當(dāng)前下標(biāo)上的值和以該值為下標(biāo)的位置上的值進(jìn)行交換,如果該值下標(biāo)位置上的值和其相等,則說(shuō)明該數(shù)字已經(jīng)被遍歷過(guò)一遍了。

代碼如下:

    public List findDuplicates(int[] nums) {
        int index = 0;
        List result = new ArrayList();
        while(index < nums.length) {
            int num = nums[index];
            if(num == 0){
                index++;
            }else if (nums[num-1] == num) {
                if(index != num-1){
                    result.add(num);
                    nums[index] = 0;
                }
                index++;
            }else{
                swap(index, num-1, nums);
            }
        }
        return result;
    }
    
    public void swap(int i, int j, int[] nums) {
        int tmp = nums[i];
        nums[i] = nums[j];
        nums[j] = tmp;
    }
思路二:取反

有沒(méi)有一種辦法在既保留當(dāng)前位置上的值nums[i]的同時(shí),又能夠用某種方式記錄i+1是否已經(jīng)被訪問(wèn)過(guò)了?可以通過(guò)取反的方法來(lái)記錄是否被訪問(wèn)過(guò)這個(gè)情況。如果訪問(wèn)到下標(biāo)為i的位置上的值,則去判斷nums[nums[i]-1]位置上的值是否為負(fù)數(shù),如果是,則說(shuō)明num[i]出現(xiàn)了兩次,否則將nums[nums[i]-1]位置上的值取反保留。

代碼如下:

    public List findDuplicates(int[] nums) {
        List res = new ArrayList<>();
        for (int i = 0; i < nums.length; ++i) {
            int index = Math.abs(nums[i])-1;
            if (nums[index] < 0)
                res.add(Math.abs(index+1));
            nums[index] = -nums[index];
        }
        return res;
    }

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/75113.html

相關(guān)文章

  • [LeetCode] 442. Find All Duplicates in an Array

    Problem Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once. Find all the elements that appear twice in this array. Could you do it without ...

    liukai90 評(píng)論0 收藏0
  • 前端 | 每天一個(gè) LeetCode

    摘要:在線網(wǎng)站地址我的微信公眾號(hào)完整題目列表從年月日起,每天更新一題,順序從易到難,目前已更新個(gè)題。這是項(xiàng)目地址歡迎一起交流學(xué)習(xí)。 這篇文章記錄我練習(xí)的 LeetCode 題目,語(yǔ)言 JavaScript。 在線網(wǎng)站:https://cattle.w3fun.com GitHub 地址:https://github.com/swpuLeo/ca...我的微信公眾號(hào): showImg(htt...

    張漢慶 評(píng)論0 收藏0
  • [LeetCode] 491. Increasing Subsequences

    Problem Given an integer array, your task is to find all the different possible increasing subsequences of the given array, and the length of an increasing subsequence should be at least 2 . Example: ...

    wupengyu 評(píng)論0 收藏0
  • [Leetcode] Contains Duplicate 包含重復(fù)

    摘要:代碼集合法復(fù)雜度時(shí)間空間思路同樣使用集合,但這次我們要維護(hù)集合的大小不超過(guò),相當(dāng)于是記錄一個(gè)寬度為的窗口中出現(xiàn)過(guò)的數(shù)字。 Contains Duplicate I Given an array of integers, find if the array contains any duplicates. Your function should return true if any v...

    rozbo 評(píng)論0 收藏0
  • leetcode217.219.220 contains duplicate

    摘要:輸入一個(gè)整數(shù)數(shù)組,查看數(shù)組中是否存在重復(fù)的值。新的數(shù)組中數(shù)組的下標(biāo)為原數(shù)組的值,如果遍歷過(guò),則設(shè)置為。這里使用了作為實(shí)現(xiàn)的數(shù)據(jù)結(jié)構(gòu),通過(guò)堆的形式對(duì)集合中的數(shù)據(jù)進(jìn)行存儲(chǔ),從而我們可以通過(guò)某種順序獲得該集合中的所有順序。 217 Contains Duplicate Given an array of integers, find if the array contains any dup...

    tulayang 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<