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

資訊專欄INFORMATION COLUMN

[Leetcode] Missing Number and Missing First Positi

Forest10 / 1798人閱讀

摘要:代碼映射法復(fù)雜度時間空間思路核心思想就是遍歷數(shù)組時,將每個元素,和以該元素為下標(biāo)的元素進行置換,比如第一個元素是,就將它置換到下標(biāo)為的地方,而原本下標(biāo)為的地方的元素就換到第一個來。

Missing Number

Given an array containing n distinct numbers taken from 0, 1, 2, ..., n, find the one that is missing from the array.

For example, Given nums = [0, 1, 3] return 2.

Note: Your algorithm should run in linear runtime complexity. Could you implement it using only constant extra space complexity?

二分搜索法 Binary Search 復(fù)雜度

時間 O(NlogN) 空間 O(1)

思路

先將數(shù)組排序,然后進行二分搜索。顯然,中點的下標(biāo)和中點的值相同時,說明從起始到中點沒有錯位,缺失數(shù)應(yīng)該在數(shù)組后邊。如果不相等,說明前面已經(jīng)有錯位,缺失數(shù)在左邊。如果缺失數(shù)是最后一個的話,那整個數(shù)組都沒有錯位,則要返回最后一個加1。

注意

雖然原題中這個方法并不是最優(yōu)的,但如果題目中的數(shù)組已經(jīng)排序的了,那二分法就比其他兩個方法要好了。

代碼
public class Solution {
    public int missingNumber(int[] nums) {
        Arrays.sort(nums);
        int min = 0, max = nums.length - 1;
        while(min < max){
            int mid = (min + max) / 2;
            // 沒錯位,在右邊。有錯位,則在左邊
            if(mid == nums[mid]){
                min = mid + 1;
            } else {
                max = mid - 1;
            }
        }
        // 如果沒有錯位,則返回最后一個數(shù)加1
        return nums[min] == min ? min + 1 : min;
    }
}
等差數(shù)列計算法 Arithmetic Progression 復(fù)雜度

時間 O(N) 空間 O(1)

思路

由題意,大小為n的數(shù)組里的所有數(shù)都是0 - n之間的數(shù),作為等差數(shù)列,如果沒有缺失的時候它的和是能O(1)計算出來的,所以我們遍歷一遍記錄最大、最小和數(shù)組和,用期望數(shù)組和減去實際數(shù)組和,就是缺失的整數(shù)

注意

缺失0和缺失n的時候要特殊處理,因為他們倆的期望和減去實際和都是0。記錄最小值可以用來判斷是否缺失0。

代碼
public class Solution {
    public int missingNumber(int[] nums) {
        if(nums.length == 0) return 0;
        int max =0, min= nums[0], sum = 0;
        for(int i = 0; i < nums.length; i++){
            sum += nums[i];
            max = Math.max(max, nums[i]);
            min = Math.min(min, nums[i]);
        }
        int correctSum = (max + 0) * (max - 0 + 1) / 2;
        return correctSum - sum;
    }
}
異或法 Exclusive OR 復(fù)雜度

時間 O(N) 空間 O(1)

思路

根據(jù)異或的特性,對于一個數(shù),異或自己是0,異或0是自己,所以我們把0-n都異或一遍,再對著給定數(shù)組異或一遍,結(jié)果就是缺失的數(shù)。

代碼
public class Solution {
    public int missingNumber(int[] nums) {
        int res = 0;
        for(int i = 0; i <= nums.length; i++){
            res ^= i == nums.length ? i : i ^ nums[i];
        }
        return res;
    }
}
First Missing Positive

Given an unsorted integer array, find the first missing positive integer.

For example, Given [1,2,0] return 3, and [3,4,-1,1] return 2.

Your algorithm should run in O(n) time and uses constant space.

映射法 復(fù)雜度

時間 O(N) 空間 O(1)

思路

核心思想就是遍歷數(shù)組時,將每個元素,和以該元素為下標(biāo)的元素進行置換,比如第一個元素是3,就將它置換到下標(biāo)為3的地方,而原本下標(biāo)為3的地方的元素就換到第一個來。如果換來的元素也是在正確的位置就檢查下一個元素,否則繼續(xù)交換,直到:

待交換的兩個數(shù)是一樣的

當(dāng)前位置的元素沒有對應(yīng)的目的地(比如負數(shù),或者超界元素)

注意

數(shù)組是從0開始的,而正數(shù)是從1開始的,為了簡化映射關(guān)系,把數(shù)組里所有元素都減了1,最后返回答案時再加1即可。

如果最后還沒找到,就說明缺失的是最后一個數(shù)n

代碼
public class Solution {
    public int firstMissingPositive(int[] nums) {
        //減1預(yù)處理數(shù)組,簡化映射關(guān)系
        for(int i = 0; i < nums.length; i++){
            nums[i]--;
        }
        for(int i = 0; i < nums.length;i++){
            while(nums[i]!=i && nums[i] >=0 && nums[i]           
               
                                           
                       
                 

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

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

相關(guān)文章

  • [LeetCode] 41. First Missing Positive

    Problem Given an unsorted integer array, find the smallest missing positive integer. Example 1: Input: [1,2,0]Output: 3Example 2: Input: [3,4,-1,1]Output: 2Example 3: Input: [7,8,9,11,12]Output: 1Note...

    30e8336b8229 評論0 收藏0
  • LeetCode 之 JavaScript 解答第41題 —— 缺失的第一個正數(shù)(First Mis

    摘要:小鹿題目算法思路桶排序思想。再遍歷數(shù)組,從下標(biāo)開始判斷該下標(biāo)是否存放規(guī)定的數(shù)據(jù),如果不是則該下標(biāo)就是這組數(shù)據(jù)中缺失的最小正整數(shù)。桶排序還可以實現(xiàn)在一組數(shù)據(jù)中查找重復(fù)的數(shù)據(jù)。 Time:2019/4/6Title: First Missing PositiveDifficulty: DifficultyAuthor: 小鹿 題目:First Missing Positive Give...

    levius 評論0 收藏0
  • leetcode 41. First Missing Positive

    摘要:題目要求在數(shù)組中找到第一個漏掉的正整數(shù)。思路一暴力排序后尋找排序后尋找顯然是最快的。這些臨時變量可以是排除出的量,也可以是有效量。當(dāng)遇到的數(shù)字為有效數(shù)字時,則將該數(shù)字放到對應(yīng)當(dāng)前起始下標(biāo)其相應(yīng)的位置上。 題目要求 Given an unsorted integer array, find the first missing positive integer. For example,...

    smallStone 評論0 收藏0
  • leetcode 268 Missing Number

    摘要:題目詳情題目的意思是輸入一個長度為的數(shù)組,找到這個數(shù)字中不存在于數(shù)組中的丟失的數(shù)字思路我的想法是,用這個數(shù)的和減去數(shù)組中的每一個元素的值,最后剩下的值就是丟失的數(shù)字解法 題目詳情 Given an array containing n distinct numbers taken from 0, 1, 2, ..., n, find the one that is missing fr...

    tianyu 評論0 收藏0
  • [LintCode/LeetCode] Set Mismatch

    Problem The set S originally contains numbers from 1 to n. But unfortunately, due to the data error, one of the numbers in the set got duplicated to another number in the set, which results in repetit...

    Astrian 評論0 收藏0

發(fā)表評論

0條評論

Forest10

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<