Day66 最長連續(xù)序列

給定一個(gè)未排序的整數(shù)數(shù)組 nums 涩拙,找出數(shù)字連續(xù)的最長序列(不要求序列元素在原數(shù)組中連續(xù))的長度

進(jìn)階:你可以設(shè)計(jì)并實(shí)現(xiàn)時(shí)間復(fù)雜度為 O(n) 的解決方案嗎际长?

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

示例1:

輸入:nums = [100,4,200,1,3,2]
輸出:4
解釋:最長數(shù)字連續(xù)序列是 [1, 2, 3, 4]。它的長度為 4兴泥。

示例2:

輸入:nums = [0,3,7,2,5,8,4,6,0,1]
輸出:9

提示:

0 <= nums.length <= 104
-109 <= nums[i] <= 109

Java解法

思路:

  • 最簡單直接的方法:先排序也颤,再記錄連續(xù)值,能計(jì)算但效率不高

  • 官方解利用hashset來進(jìn)行查找郁轻,這里有個(gè)模糊點(diǎn)翅娶,hashset的contains方法的時(shí)間復(fù)雜度的問題,這里是波動(dòng)的好唯,通過HashSet源碼可以發(fā)現(xiàn)hashset內(nèi)部持有了一個(gè)特殊的HashMap(value為Object PRESENT = new Object())他的contains方法即為hashmap的方法竭沫,在這里,也有遍歷骑篙,所有不能完全定義為O(1)蜕提,這與hashset的table長度有關(guān),但經(jīng)過table數(shù)組的處理是必定小于O(n)的

    image

package sj.shimmer.algorithm.m4_2021;

/**
 * Created by SJ on 2021/4/3.
 */

class D66 {
    public static void main(String[] args) {
        System.out.println(longestConsecutive(new int[]{100,4,200,1,3,2}));
        System.out.println(longestConsecutive(new int[]{0,3,7,2,5,8,4,6,0,1}));
        System.out.println(longestConsecutive(new int[]{1,2,0,1}));
    }
    public static int longestConsecutive(int[] nums) {
        int result = 0;
        if (nums != null) {
            int[] swap = quickSwap(nums, 0, nums.length-1);
            int temp = 0;
            for (int i = 0; i < swap.length; i++) {
                temp++;
                if (i+1<swap.length) {
                    if (swap[i+1] == swap[i]){
                        temp--;
                    }else if (swap[i+1] != swap[i]+1){
                        result = Math.max(result,temp);
                        temp = 0;
                    }
                }
            }
            result = Math.max(result,temp);
        }
        return result;
    }
    public static int[] quickSwap(int[] nums, int startIndex, int endIndex) {
        if (startIndex < endIndex) {
            int mid = findPosition(nums, startIndex, endIndex);
            quickSwap(nums, startIndex, mid - 1);
            quickSwap(nums, mid + 1, endIndex);
        }
        return nums;
    }
    public static int findPosition(int[] args, int start, int end) {
        int pivot = args[start];//以左側(cè)為基準(zhǔn)值
        while (start < end) {//為雙指針靶端, 重合時(shí)跳出
            // 從右向左尋找谎势,一直找到比參照值還小的數(shù)值,進(jìn)行替換
            while (start < end && args[end] >= pivot) {
                end--;//找到比基準(zhǔn)值小的數(shù)值的位置
            }
            if (start < end) {
                //因?yàn)榛鶞?zhǔn)值已被記錄杨名,所以直接更新即可脏榆,args[end]會(huì)在下一次更新
                args[start] = args[end];
            }
            // 從左向右尋找,一直找到比參照值還大的數(shù)組台谍,進(jìn)行替換
            while (start < end && args[start] < pivot) {
                start++;
            }
            if (start < end) {
                args[end] = args[start];
            }
        }
        args[start] = pivot;//此時(shí) 雙指針都指向了應(yīng)該在的位置须喂,更新該值即可
        return start;
    }
}
image

官方解

https://leetcode-cn.com/problems/longest-consecutive-sequence/solution/zui-chang-lian-xu-xu-lie-by-leetcode-solution/

  1. 哈希表

    利用hashset去重這一步很機(jī)智,我就忽略了

    class Solution {
       public  int longestConsecutive(int[] nums) {
            int result = 0;
                 Set<Integer> num_set = new HashSet<Integer>();
            for (int num : nums) {
                num_set.add(num);
            }
    
            int longestStreak = 0;
    
            for (int num : num_set) {
                if (!num_set.contains(num - 1)) {
                    int currentNum = num;
                    int currentStreak = 1;
    
                    while (num_set.contains(currentNum + 1)) {
                        currentNum += 1;
                        currentStreak += 1;
                    }
    
                    longestStreak = Math.max(longestStreak, currentStreak);
                }
            }
    
            return longestStreak;
        }
    
    image
    • 時(shí)間復(fù)雜度:O(n),時(shí)間復(fù)雜度因?yàn)槲窗琧ontains的考慮,所以這里個(gè)人覺得不能認(rèn)定為O(n)

    • 空間復(fù)雜度:O(n)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末坞生,一起剝皮案震驚了整個(gè)濱河市仔役,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌是己,老刑警劉巖又兵,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異卒废,居然都是意外死亡寒波,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門升熊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來俄烁,“玉大人,你說我怎么就攤上這事级野∫惩溃” “怎么了?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵蓖柔,是天一觀的道長辰企。 經(jīng)常有香客問我,道長况鸣,這世上最難降的妖魔是什么牢贸? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮镐捧,結(jié)果婚禮上潜索,老公的妹妹穿的比我還像新娘。我一直安慰自己懂酱,他們只是感情好竹习,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著列牺,像睡著了一般整陌。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瞎领,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天泌辫,我揣著相機(jī)與錄音,去河邊找鬼九默。 笑死震放,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的荤西。 我是一名探鬼主播澜搅,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼伍俘,長吁一口氣:“原來是場噩夢啊……” “哼邪锌!你這毒婦竟也來了勉躺?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤觅丰,失蹤者是張志新(化名)和其女友劉穎饵溅,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體妇萄,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蜕企,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了冠句。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片轻掩。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖懦底,靈堂內(nèi)的尸體忽然破棺而出唇牧,到底是詐尸還是另有隱情,我是刑警寧澤聚唐,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布丐重,位于F島的核電站,受9級(jí)特大地震影響杆查,放射性物質(zhì)發(fā)生泄漏扮惦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一亲桦、第九天 我趴在偏房一處隱蔽的房頂上張望崖蜜。 院中可真熱鬧,春花似錦客峭、人聲如沸纳猪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽氏堤。三九已至,卻和暖如春搏明,著一層夾襖步出監(jiān)牢的瞬間鼠锈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國打工星著, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留购笆,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓虚循,卻偏偏與公主長得像同欠,于是被迫代替她去往敵國和親样傍。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容