力扣(LeetCode) - 300 最長上升子序列

本題用動態(tài)規(guī)劃和二分查找可解

一古涧、題目

給定一個無序的整數(shù)數(shù)組垂券,找到其中最長上升子序列的長度。

示例:

輸入: [10,9,2,5,3,7,101,18]
輸出: 4 
解釋: 最長的上升子序列是 [2,3,7,101]蒿褂,它的長度是 4圆米。

說明:
可能會有多種最長上升子序列的組合,你只需要輸出對應的長度即可啄栓。你算法的時間復雜度應該為 O(n^2) 。

進階:你能將算法的時間復雜度降低到 O(n log n) 嗎?

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/longest-increasing-subsequence

二也祠、分析

2.1 題目分析

原始的數(shù)組是一個無序數(shù)組昙楚,要從無序數(shù)組中找到最長上升子序列。這個子序列的元素在原始數(shù)組中不要求是連續(xù)的诈嘿,并且子序列的元素必須是嚴格遞增的堪旧。
也就是說如果原始數(shù)組是 [10,9,2,5,3,7,101,18]削葱,那么 [2,3,7,101]就是一個最長的上升子序列。

2.2 回溯淳梦?

如果我們用回溯法來遍歷數(shù)組析砸,時間復雜度是2^n次方,這是不能接收的爆袍。

2.3 動態(tài)規(guī)劃

既然題目要求的是最長子序列的長度首繁,那么我們可以使用動態(tài)規(guī)劃,啟動dp[i]保存的就是以第 i個數(shù)字結(jié)尾的最長子序列的長度陨囊。
也就是說弦疮,如果原始數(shù)組src [] = {10, 3, 5, 2};
則dp[] 應為是 {1, 1, 2, 1}

我們應該把狀態(tài)轉(zhuǎn)移公式求出來。


動態(tài)規(guī)劃的狀態(tài)轉(zhuǎn)移方程

基于上面的公式蜘醋,我們可以寫出下面的代碼

    public int lengthOfLIS(int[] nums) {
        if (nums == null || nums.length == 0) {
            return 0;
        }
        int[] dp = new int[nums.length];  //記錄以第i個數(shù)組結(jié)尾的最長上升序列
        int res = 0;
        for (int i = 0; i < nums.length; i++) {
            dp[i] = 1;
            for (int j = 0; j < i; j++) {  // dp[i] = max(dp[j] + 1) && dp[j] < dp[i] && 0 <= j < i
                if (nums[j] < nums[i]) {
                    dp[i] = Math.max(dp[i], dp[j] + 1);
                }
            }
            res = Math.max(res, dp[i]);
        }
        return res;
    }

代碼的時間復雜度是 n^2

2.4 動態(tài)規(guī)劃+二分查找

如果將時間復雜度提高到nlogn胁塞,那么就需要修改一下思路。
我們用dp[i]保存所有長度為i + 1的上升序列的最后一個元素中最小的那一個压语。
因此啸罢,對于src[] = {10, 9, 2, 5, 3, 7, 101, 18}
遍歷數(shù)組,dp對應為

i = 0 dp = {10}
i = 1 dp = {9}
i = 2 dp = {2}
i = 3 dp = {2, 5}
i = 4 dp = {2, 3}
i = 5 dp = {2, 3, 7}
i = 6 dp = {2, 3, 7, 101}
i = 7 dp = {2, 3, 7, 18}

由于dp數(shù)組是嚴格上升的胎食,那么我們可以用二分查找的方式更新dp數(shù)組扰才,這樣總的時間復雜度就是nlogn。
代碼如下

    public int lengthOfLIS(int[] nums) {
        if (nums == null || nums.length == 0) {
            return 0;
        }
        int[] dp = new int[nums.length]; // dp[i] 標識所有長度為i+1的序列中斥季,最小的序列尾數(shù)
        int maxLen = 1;
        dp[0] = nums[0];
        for (int cur : nums) {
            if (cur > dp[maxLen - 1]) {
                dp[maxLen] = cur;
                maxLen++;
            } else {
                int start = 0;
                int end = maxLen - 1;
                while (start < end) {  //二分查找
                    int mid = (start + end) /2;
                    if (cur > dp[mid]) {
                        start = mid + 1;
                    } else {
                        end = mid;
                    }
                }
                dp[start] = cur;
            }
        }
        return maxLen;
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末训桶,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子酣倾,更是在濱河造成了極大的恐慌舵揭,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件躁锡,死亡現(xiàn)場離奇詭異午绳,居然都是意外死亡,警方通過查閱死者的電腦和手機映之,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門拦焚,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人杠输,你說我怎么就攤上這事赎败。” “怎么了蠢甲?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵僵刮,是天一觀的道長。 經(jīng)常有香客問我,道長搞糕,這世上最難降的妖魔是什么勇吊? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮窍仰,結(jié)果婚禮上汉规,老公的妹妹穿的比我還像新娘。我一直安慰自己驹吮,他們只是感情好针史,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著钥屈,像睡著了一般悟民。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上篷就,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天射亏,我揣著相機與錄音,去河邊找鬼竭业。 笑死智润,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的未辆。 我是一名探鬼主播窟绷,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼咐柜!你這毒婦竟也來了兼蜈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤拙友,失蹤者是張志新(化名)和其女友劉穎为狸,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體遗契,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡辐棒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了牍蜂。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片漾根。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖鲫竞,靈堂內(nèi)的尸體忽然破棺而出辐怕,到底是詐尸還是另有隱情,我是刑警寧澤从绘,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布秘蛇,位于F島的核電站其做,受9級特大地震影響顶考,放射性物質(zhì)發(fā)生泄漏赁还。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一驹沿、第九天 我趴在偏房一處隱蔽的房頂上張望艘策。 院中可真熱鬧,春花似錦渊季、人聲如沸朋蔫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽驯妄。三九已至,卻和暖如春合砂,著一層夾襖步出監(jiān)牢的瞬間青扔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工翩伪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留微猖,地道東北人。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓缘屹,卻偏偏與公主長得像凛剥,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子轻姿,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

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