欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實(shí)現(xiàn)LeetCode(41.首個(gè)缺失的正數(shù))

 更新時(shí)間:2021年07月15日 11:33:10   作者:Grandyang  
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(41.首個(gè)缺失的正數(shù)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 41. First Missing Positive 首個(gè)缺失的正數(shù)

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

Example 1:

Input: [1,2,0]
Output: 3

Example 2:

Input: [3,4,-1,1]
Output: 2

Example 3:

Input: [7,8,9,11,12]
Output: 1

Note:

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

這道題讓我們找缺失的首個(gè)正數(shù),由于限定了 O(n) 的時(shí)間,所以一般的排序方法都不能用,最開(kāi)始博主沒(méi)有看到還限制了空間復(fù)雜度,所以想到了用 HashSet 來(lái)解,這個(gè)思路很簡(jiǎn)單,把所有的數(shù)都存入 HashSet 中,然后循環(huán)從1開(kāi)始遞增找數(shù)字,哪個(gè)數(shù)字找不到就返回哪個(gè)數(shù)字,如果一直找到了最大的數(shù)字(這里是 nums 數(shù)組的長(zhǎng)度),則加1后返回結(jié)果 res,參見(jiàn)代碼如下:

解法一:

// NOT constant space
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        unordered_set<int> st(nums.begin(), nums.end());
        int res = 1, n = nums.size();
        while (res <= n) {
            if (!st.count(res)) return res;
            ++res;
        }
        return res;
    }
};

但是上面的解法不是 O(1) 的空間復(fù)雜度,所以需要另想一種解法,既然不能建立新的數(shù)組,那么只能覆蓋原有數(shù)組,思路是把1放在數(shù)組第一個(gè)位置 nums[0],2放在第二個(gè)位置 nums[1],即需要把 nums[i] 放在 nums[nums[i] - 1]上,遍歷整個(gè)數(shù)組,如果 nums[i] != i + 1, 而 nums[i] 為整數(shù)且不大于n,另外 nums[i] 不等于 nums[nums[i] - 1] 的話(huà),將兩者位置調(diào)換,如果不滿(mǎn)足上述條件直接跳過(guò),最后再遍歷一遍數(shù)組,如果對(duì)應(yīng)位置上的數(shù)不正確則返回正確的數(shù),參見(jiàn)代碼如下:

解法二:

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

到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(41.首個(gè)缺失的正數(shù))的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)首個(gè)缺失的正數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++ 中assert()函數(shù)用法總結(jié)

    C++ 中assert()函數(shù)用法總結(jié)

    這篇文章主要介紹了C++ 中assert()函數(shù)用法總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法

    C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法

    這篇文章主要介紹了C++設(shè)置超時(shí)時(shí)間的簡(jiǎn)單實(shí)現(xiàn)方法,涉及系統(tǒng)函數(shù)setsockopt對(duì)套接口的操作,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • Qt在vs2019中使用及設(shè)置方法

    Qt在vs2019中使用及設(shè)置方法

    這篇文章主要介紹了Qt在vs2019中使用及設(shè)置方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • C++異常處理入門(mén)(try和catch)

    C++異常處理入門(mén)(try和catch)

    C++ 提供了異常機(jī)制,讓我們能夠捕獲運(yùn)行時(shí)錯(cuò)誤,本文就詳細(xì)的介紹了C++異常處理入門(mén),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • C++基于CMD命令行實(shí)現(xiàn)掃雷小游戲

    C++基于CMD命令行實(shí)現(xiàn)掃雷小游戲

    這篇文章主要為大家詳細(xì)介紹了C++基于CMD命令行實(shí)現(xiàn)掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C語(yǔ)言宏函數(shù)container of()簡(jiǎn)介

    C語(yǔ)言宏函數(shù)container of()簡(jiǎn)介

    這篇文章介紹了C語(yǔ)言宏函數(shù)container of(),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12
  • C語(yǔ)言實(shí)現(xiàn)素因子分解

    C語(yǔ)言實(shí)現(xiàn)素因子分解

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)素因子分解,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 利用Matlab一鍵生成工地海報(bào)特效

    利用Matlab一鍵生成工地海報(bào)特效

    這篇文章主要介紹了如何利用Matlab制作出工地海報(bào)的特效,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下
    2022-03-03
  • C++實(shí)踐分?jǐn)?shù)類(lèi)中運(yùn)算符重載的方法參考

    C++實(shí)踐分?jǐn)?shù)類(lèi)中運(yùn)算符重載的方法參考

    今天小編就為大家分享一篇關(guān)于C++實(shí)踐分?jǐn)?shù)類(lèi)中運(yùn)算符重載的方法參考,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2019-02-02
  • C++數(shù)據(jù)結(jié)構(gòu)二叉搜索樹(shù)的實(shí)現(xiàn)應(yīng)用與分析

    C++數(shù)據(jù)結(jié)構(gòu)二叉搜索樹(shù)的實(shí)現(xiàn)應(yīng)用與分析

    從這篇博客開(kāi)始,我就要和大家介紹有關(guān)二叉搜索樹(shù)的知識(shí),它還衍生出了兩棵樹(shù)——AVL樹(shù)和紅黑樹(shù),在后面兩篇博客我都會(huì)介紹。今天先從二叉搜索樹(shù)開(kāi)始引入
    2022-02-02

最新評(píng)論