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

C++實現(xiàn)LeetCode(128.求最長連續(xù)序列)

 更新時間:2021年07月27日 14:37:04   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(128.求最長連續(xù)序列),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下

[LeetCode] 128.Longest Consecutive Sequence 求最長連續(xù)序列

Given an unsorted array of integers, find the length of the longest consecutive elements sequence.

Your algorithm should run in O(n) complexity.

Example:

Input: [100, 4, 200, 1, 3, 2]
Output: 4
Explanation: The longest consecutive elements sequence is

[1, 2, 3, 4]

. Therefore its length is 4.

這道題要求求最長連續(xù)序列,并給定了O(n)復雜度限制,我們的思路是,使用一個集合HashSet存入所有的數(shù)字,然后遍歷數(shù)組中的每個數(shù)字,如果其在集合中存在,那么將其移除,然后分別用兩個變量pre和next算出其前一個數(shù)跟后一個數(shù),然后在集合中循環(huán)查找,如果pre在集合中,那么將pre移除集合,然后pre再自減1,直至pre不在集合之中,對next采用同樣的方法,那么next-pre-1就是當前數(shù)字的最長連續(xù)序列,更新res即可。這里再說下,為啥當檢測某數(shù)字在集合中存在當時候,都要移除數(shù)字。這是為了避免大量的重復計算,就拿題目中的例子來說吧,我們在遍歷到4的時候,會向下遍歷3,2,1,如果都不移除數(shù)字的話,遍歷到1的時候,還會遍歷2,3,4。同樣,遍歷到3的時候,向上遍歷4,向下遍歷2,1,等等等。如果數(shù)組中有大量的連續(xù)數(shù)字的話,那么就有大量的重復計算,十分的不高效,所以我們要從HashSet中移除數(shù)字,代碼如下:

C++ 解法一:

class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        int res = 0;
        unordered_set<int> s(nums.begin(), nums.end());
        for (int val : nums) {
            if (!s.count(val)) continue;
            s.erase(val);
            int pre = val - 1, next = val + 1;
            while (s.count(pre)) s.erase(pre--);
            while (s.count(next)) s.erase(next++);
            res = max(res, next - pre - 1);
        }
        return res;
    }
};

Java 解法一:

public class Solution {
    public int longestConsecutive(int[] nums) {
        int res = 0;
        Set<Integer> s = new HashSet<Integer>();
        for (int num : nums) s.add(num);
        for (int num : nums) {
            if (s.remove(num)) {
                int pre = num - 1, next = num + 1;
                while (s.remove(pre)) --pre;
                while (s.remove(next)) ++next;
                res = Math.max(res, next - pre - 1);
            }
        }
        return res;
    }
}

我們也可以采用哈希表來做,剛開始HashMap為空,然后遍歷所有數(shù)字,如果該數(shù)字不在HashMap中,那么我們分別看其左右兩個數(shù)字是否在HashMap中,如果在,則返回其哈希表中映射值,若不在,則返回0,雖然我們直接從HashMap中取不存在的映射值,也能取到0,但是一旦去取了,就會自動生成一個為0的映射,那么我們這里再for循環(huán)的開頭判斷如果存在映射就跳過的話,就會出錯。然后我們將left+right+1作為當前數(shù)字的映射,并更新res結果,同時更新num-left和num-right的映射值。

下面來解釋一下為啥要判斷如何存在映射的時候要跳過,這是因為一旦某個數(shù)字創(chuàng)建映射了,說明該數(shù)字已經(jīng)被處理過了,那么其周圍的數(shù)字很可能也已經(jīng)建立好了映射了,如果再遇到之前處理過的數(shù)字,再取相鄰數(shù)字的映射值累加的話,會出錯。舉個例子,比如數(shù)組 [1, 2, 0, 1],當0執(zhí)行完以后,HashMap中的映射為 {1->2, 2->3, 0->3},可以看出此時0和2的映射值都已經(jīng)為3了,那么如果最后一個1還按照原來的方法處理,隨后得到結果就是7,明顯不合題意。還有就是,之前說的,為了避免訪問不存在的映射值時,自動創(chuàng)建映射,我們使用m.count() 先來檢測一下,只有存在映射,我們才從中取值,否則就直接賦值為0,參見代碼如下:

C++ 解法二:

class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        int res = 0;
        unordered_map<int, int> m;
        for (int num : nums) {
            if (m.count(num)) continue;
            int left = m.count(num - 1) ? m[num - 1] : 0;
            int right = m.count(num + 1) ? m[num + 1] : 0;
            int sum = left + right + 1;
            m[num] = sum;
            res = max(res, sum);
            m[num - left] = sum;
            m[num + right] = sum;
        }
        return res;
    }
};

Java 解法二:

public class Solution {
    public int longestConsecutive(int[] nums) {
        int res = 0;
        Map<Integer, Integer> m = new HashMap<Integer, Integer>();
        for (int num : nums) {
            if (m.containsKey(num)) continue;
            int left = m.containsKey(num - 1) ? m.get(num - 1) : 0;
            int right = m.containsKey(num + 1) ? m.get(num + 1) : 0;
            int sum = left + right + 1;
            m.put(num, sum);
            res = Math.max(res, sum);
            m.put(num - left, sum);
            m.put(num + right, sum);
        }
        return res;
    }
}

類似題目:

Binary Tree Longest Consecutive Sequence

參考資料:

https://leetcode.com/problems/longest-consecutive-sequence/

https://leetcode.com/problems/longest-consecutive-sequence/discuss/41055/my-really-simple-java-on-solution-accepted

https://leetcode.com/problems/longest-consecutive-sequence/discuss/41060/a-simple-csolution-using-unordered_setand-simple-consideration-about-this-problem

到此這篇關于C++實現(xiàn)LeetCode(128.求最長連續(xù)序列)的文章就介紹到這了,更多相關C++實現(xiàn)求最長連續(xù)序列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vs2019創(chuàng)建WebService服務的實現(xiàn)

    vs2019創(chuàng)建WebService服務的實現(xiàn)

    這篇文章主要介紹了vs2019創(chuàng)建WebService服務的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • c++ 構造函數(shù)中調用虛函數(shù)的實現(xiàn)方法

    c++ 構造函數(shù)中調用虛函數(shù)的實現(xiàn)方法

    下面小編就為大家?guī)硪黄猚++ 構造函數(shù)中調用虛函數(shù)的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • C++實現(xiàn)簡單的計算器功能

    C++實現(xiàn)簡單的計算器功能

    這篇文章主要為大家詳細介紹了C++實現(xiàn)簡單的計算器功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C++ 流插入和流提取運算符的重載的實現(xiàn)

    C++ 流插入和流提取運算符的重載的實現(xiàn)

    這篇文章主要介紹了C++ 流插入和流提取運算符的重載的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • C++封裝遠程注入類CreateRemoteThreadEx實例

    C++封裝遠程注入類CreateRemoteThreadEx實例

    這篇文章主要介紹了C++封裝遠程注入類CreateRemoteThreadEx實例,詳細講述了注入DLL到指定的地址空間以及從指定的地址空間卸載DLL的方法,需要的朋友可以參考下
    2014-10-10
  • 如何在C語言中提取Shellcode并執(zhí)行

    如何在C語言中提取Shellcode并執(zhí)行

    Shellcode是一種獨立于應用程序的機器代碼,通常用于實現(xiàn)特定任務,如執(zhí)行遠程命令、注入惡意軟件或利用系統(tǒng)漏洞,本文將深入探討如何在C語言中提取Shellcode,并通過XOR加密技術增加其混淆程度,文中通過代碼示例講解的非常詳細,需要的朋友可以參考下
    2023-12-12
  • C語言求連續(xù)最大子數(shù)組和的方法

    C語言求連續(xù)最大子數(shù)組和的方法

    這篇文章主要介紹了C語言求連續(xù)最大子數(shù)組和的方法,包含了數(shù)組的常見操作及相關技巧,需要的朋友可以參考下
    2014-09-09
  • VC++ 中ListCtrl經(jīng)驗總結

    VC++ 中ListCtrl經(jīng)驗總結

    這篇文章主要介紹了VC++ 中ListCtrl經(jīng)驗總結的相關資料,需要的朋友可以參考下
    2015-06-06
  • C++實現(xiàn)LeetCode(904.水果裝入果籃)

    C++實現(xiàn)LeetCode(904.水果裝入果籃)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(904.水果裝入果籃),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++ 實現(xiàn)輸入含空格的字符串

    C++ 實現(xiàn)輸入含空格的字符串

    這篇文章主要介紹了C++ 實現(xiàn)輸入含空格的字符串,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12

最新評論