300. 最長上升子序列

300. 最長上升子序列

1.想法

最開始我想用回溯法做,但是發(fā)現(xiàn)整個算法的時間復(fù)雜度非常大

  • 1.回溯法:


    image.png

    每一層的選擇都不影響上一層的選擇,遍歷所有情況最終得到所有的結(jié)果,找出一直遞增的結(jié)果


    image.png

    以題目為例:
  1. 如果選擇了10,那么接下來到9就判斷是否能選,因為9<10所以不能選,只能再看下一個,直到101,大于10,所以可以選擇,那么選擇101,計數(shù)+1,并且最大的數(shù)更換成101
  2. 如果不選擇10,那么9就可以選擇,選擇9的情況下,暫時最大數(shù)是9,那么同樣的道理到101發(fā)現(xiàn)可以更新
  3. 重復(fù)以上過程,直到選擇的次數(shù)達到數(shù)組長度,遞歸結(jié)束

總結(jié):由于每個數(shù)都有兩次的選擇機會,所以時間復(fù)雜度為O(2^n).不滿足條件,所以必須要降低時間復(fù)雜度:降低時間復(fù)雜度的方法,以空間換時間 能以空間換時間的1.直接的容器存儲 不涉及遞歸或者迭代的過程 2.涉及遞歸或者迭代的過程 很明顯貪心法無法直接完成這個過程,那么利用動態(tài)規(guī)劃

2.動態(tài)規(guī)劃


image.png

那么按照動態(tài)規(guī)劃的一般過程進行處理就可以了

1.建模

①解:<max>代表了最長的那么解
②目標函數(shù):max = max(f(0),f(1),...f(n-1))

③約束條件:nums[n]>nums[j] 其中j<n;

2.子問題優(yōu)化

1.當n=0時,f(0)=1;
2.當nums[i]>nums[j]&&i>j時:f[i] = f[j]+1
3.當nums[i]<nums[j]&&i<j時,跳過

3.歸結(jié)公式

f(n) \begin{cases} max(f(j))+1, &當n>j且nums[n]>nums[j]時;\\ 1, &當n=1或nums[n]<所有nums[j]且n>j;\\ \end{cases}

就是說:找出前面所有數(shù)字比現(xiàn)數(shù)字小且其增長序列是最長的

2.代碼:

1.回溯法:(超時)

 int maxCount = 0;
    public int lengthOfLIS(int[] nums) {
      MyBackTracking(nums,0,0,Integer.MIN_VALUE); //回溯開始
      return maxCount;
    }

    private void MyBackTracking(int[] nums, int count, int size,int max) {
        if(count == nums.length){   //選擇完畢
            if(size>maxCount){
                maxCount  = size;
            }
        }else{
            if(nums[count]>max){   //若可選擇,則選擇,并更新最新的長度和最大值
                MyBackTracking(nums,count+1,size+1,nums[count]);
            }
            MyBackTracking(nums,count+1,size,max); //不可選擇或者選擇另一種
        }
    }
回溯法

2.動態(tài)規(guī)劃:

    public int lengthOfLIS(int[] nums) {
        int max = 0;
        int[] f = new int[nums.length];
        for (int i = 0; i < nums.length; i++) {
            for (int j = 0; j < i; j++) {
                if (nums[i] > nums[j] && f[j] + 1 > f[i]) {  //從以前的取值中選出最大的
                    f[i] = f[j] + 1;
                }
            }
            if (f[i] == 0) {  //比別人都小或者是第一個元素
                f[i] = 1;
            }
            if (f[i] > max) {
                max = f[i];
            }
        }
        return max;
    }
最后編輯于
?著作權(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)自己被綠了散吵。 大學(xué)時的朋友給我發(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