青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 200, comments - 8, trackbacks - 0, articles - 0

最近在做單調(diào)隊列,發(fā)現(xiàn)了最長上升子序列O(nlogn)的求法也有利用單調(diào)隊列的思想。

    最長遞增子序列問題:在一列數(shù)中尋找一些數(shù),這些數(shù)滿足:任意兩個數(shù)a[i]和a[j],若i<j,必有a[i]<a[j],這樣最長的子序列稱為最長遞增子序列。

   設dp[i]表示以i為結(jié)尾的最長遞增子序列的長度,則狀態(tài)轉(zhuǎn)移方程為:

dp[i] = max{dp[j]+1}, 1<=j<i,a[j]<a[i].

   這樣簡單的復雜度為O(n^2),其實還有更好的方法。

   考慮兩個數(shù)a[x]和a[y],x<y且a[x]<a[y],且dp[x]=dp[y],當a[t]要選擇時,到底取哪一個構(gòu)成最優(yōu)的呢?顯然選取a[x]更有潛力,因為可能存在a[x]<a[z]<a[y],這樣a[t]可以獲得更優(yōu)的值。在這里給我們一個啟示,當dp[t]一樣時,盡量選擇更小的a[x].

    按dp[t]=k來分類,只需保留dp[t]=k的所有a[t]中的最小值,設d[k]記錄這個值,d[k]=min{a[t],dp[t]=k}。

    這時注意到d的兩個特點(重要):

1. d[k]在計算過程中單調(diào)不升;           

2. d數(shù)組是有序的,d[1]<d[2]<..d[n]。

    利用這兩個性質(zhì),可以很方便的求解:

1. 設當前已求出的最長上升子序列的長度為len(初始時為1),每次讀入一個新元素x:

2. 若x>d[len],則直接加入到d的末尾,且len++;(利用性質(zhì)2)

   否則,在d中二分查找,找到第一個比x小的數(shù)d[k],并d[k+1]=x,在這里x<=d[k+1]一定成立(性質(zhì)1,2)。

 

  1. /** 
  2. 最長遞增子序列O(nlogn)算法: 
  3. 狀態(tài)轉(zhuǎn)移方程:f[i] = max{f[i],f[j]+1},1<=j<i,a[j]<a[i]. 
  4. 分析:加入x<y,f[x]>=f[y],則x相對于y更有潛力。 
  5. 首先根據(jù)f[]值分類,記錄滿足f[t]=k的最小的值a[t],記d[k]=min{a[t]},f[t]=k. 
  6.     1.發(fā)現(xiàn)d[k]在計算過程中單調(diào)不上升 
  7.     2.d[1]<d[2]<...<d[k] (反證) 1 2 3 8 4 7 
  8. 解法: 
  9. 1. 設當前最長遞增子序列為len,考慮元素a[i]; 
  10. 2. 若d[len]<a[i],則len++,并將d[len]=a[i]; 
  11.    否則,在d[0-len]中二分查找,找到第一個比它小的元素d[k],并d[k+1]=a[i].() 
  12. */  
  13. #include <iostream>  
  14. #include <cstdio>  
  15. #include <cstring>  
  16. using namespace std;  
  17. const int N = 41000;  
  18. int a[N];       //a[i] 原始數(shù)據(jù)  
  19. int d[N];       //d[i] 長度為i的遞增子序列的最小值  
  20.   
  21. int BinSearch(int key, int* d, int low, int high)  
  22. {  
  23.     while(low<=high)  
  24.     {  
  25.         int mid = (low+high)>>1;  
  26.         if(key>d[mid] && key<=d[mid+1])  
  27.             return mid;  
  28.         else if(key>d[mid])  
  29.             low = mid+1;  
  30.         else  
  31.             high = mid-1;  
  32.     }  
  33.     return 0;  
  34. }  
  35.   
  36. int LIS(int* a, int n, int* d)  
  37. {  
  38.     int i,j;  
  39.     d[1] = a[1];  
  40.     int len = 1;        //遞增子序列長度  
  41.     for(i = 2; i <= n; i++)  
  42.     {  
  43.         if(d[len]<a[i])  
  44.             j = ++len;  
  45.         else  
  46.             j = BinSearch(a[i],d,1,len) + 1;  
  47.         d[j] = a[i];  
  48.     }  
  49.     return len;  
  50. }  
  51.   
  52. int main()  
  53. {  
  54.     int t;  
  55.     int p;  
  56.     scanf("%d",&t);  
  57.     while(t--)  
  58.     {  
  59.         scanf("%d",&p);  
  60.         for(int i = 1; i <= p; i++)  
  61.             scanf("%d",&a[i]);  
  62.         printf("%d\n",LIS(a,p,d));  
  63.     }  
  64.     return 0;  
  65. }  

 

Feedback

# re: 最長上升子序列 O(nlogn)解法 (轉(zhuǎn))  回復  更多評論   

2014-10-21 14:46 by 無憂
寫的不錯 謝謝
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜精品久久久久久99热| 欧美在线视频一区| 午夜老司机精品| 亚洲一区免费看| 亚洲一区二区日本| 午夜精品一区二区三区电影天堂 | 日韩午夜中文字幕| 亚洲人成人99网站| 亚洲精品美女在线观看| 亚洲私人影吧| 久久精品综合| 欧美激情第8页| 亚洲美女少妇无套啪啪呻吟| 亚洲视频一区二区| 久久精品国产2020观看福利| 欧美a级一区二区| 国产精品久久久久久av福利软件 | 国产精品久久久久一区二区三区 | 久久综合狠狠综合久久激情| 亚洲第一在线综合网站| 久久偷窥视频| 亚洲日本无吗高清不卡| 亚洲天堂成人在线观看| 久久久一区二区| 欧美片在线播放| 国内久久精品| 亚洲在线不卡| 亚洲国产精品一区制服丝袜| 亚洲专区一区二区三区| 免费观看日韩| 国产亚洲欧洲| 亚洲一二三区在线观看| 欧美夫妇交换俱乐部在线观看| 亚洲肉体裸体xxxx137| 欧美在线3区| 欧美视频一区二区三区四区| 狠狠色丁香久久婷婷综合丁香| 一区二区三区www| 免费在线亚洲| 欧美在线观看你懂的| 欧美无砖砖区免费| 日韩视频一区| 欧美激情日韩| 久久嫩草精品久久久精品一| 国产午夜精品在线观看| 亚洲免费一级电影| 亚洲美女黄网| 欧美日本高清视频| 亚洲伦伦在线| 欧美高清在线视频观看不卡| 欧美一级午夜免费电影| 国产精品综合网站| 亚洲欧美文学| 美女网站久久| 亚洲高清在线精品| 亚洲欧美日韩成人| 欧美视频日韩视频| 在线综合视频| 一本色道久久综合亚洲91| 欧美精品在线极品| 日韩视频在线观看一区二区| 欧美ed2k| 欧美大片免费观看| 亚洲精品一区在线| 亚洲电影第三页| 欧美激情一区二区三区蜜桃视频| 亚洲欧洲综合另类| 亚洲日韩中文字幕在线播放| 欧美日韩福利视频| 亚洲一区在线观看免费观看电影高清| 亚洲精品久久在线| 国产精品xvideos88| 性亚洲最疯狂xxxx高清| 欧美一级理论片| 在线电影国产精品| 亚洲国产综合在线| 欧美日韩综合| 亚洲欧美另类国产| 久久福利毛片| 亚洲精品人人| 亚洲影音一区| 激情久久久久久久久久久久久久久久| 久久先锋影音| 欧美大香线蕉线伊人久久国产精品| 亚洲精品美女| 亚洲在线网站| 亚洲第一中文字幕| 亚洲人成免费| 国产亚洲成av人片在线观看桃| 久久网站热最新地址| 欧美激情视频一区二区三区免费| 亚洲伊人观看| 久热综合在线亚洲精品| 亚洲视频一区| 久久亚洲午夜电影| 欧美激情精品久久久| 欧美亚洲尤物久久| 欧美成在线观看| 销魂美女一区二区三区视频在线| 久久精品视频网| 夜夜夜久久久| 久久精品1区| 一区二区三区欧美亚洲| 性做久久久久久久免费看| 亚洲激情影视| 欧美主播一区二区三区| 亚洲午夜视频在线观看| 久久亚洲精品一区| 欧美一区二区三区在线观看| 欧美aⅴ99久久黑人专区| 久久国产色av| 欧美日韩国产成人在线观看| 美女图片一区二区| 国产精品私房写真福利视频| 欧美国产三级| 国产真实乱子伦精品视频| 国产精品a久久久久| 欧美电影免费观看| 国产精品视频一二三| 亚洲成人自拍视频| 国产欧美一区二区精品性色| 亚洲精品一区中文| 亚洲国产精品久久人人爱蜜臀| 亚洲影院免费观看| 一区二区国产日产| 欧美二区不卡| 免费观看成人| 一区二区三区中文在线观看 | 久久亚洲欧洲| 国产日韩欧美麻豆| 欧美一区=区| 亚洲一级黄色av| 欧美日韩国产一区二区| 亚洲欧洲精品一区二区| 在线精品视频免费观看| 欧美一区免费| 久久精品久久综合| 国模精品一区二区三区| 亚洲欧美激情一区| 久久er99精品| 国产一区二区三区av电影 | 中文日韩在线视频| 欧美日本免费一区二区三区| 亚洲大片精品永久免费| 亚洲国产婷婷香蕉久久久久久99| 麻豆精品91| 91久久久久久国产精品| 一本色道久久综合亚洲精品不| 欧美福利电影网| 日韩视频免费| 午夜视频精品| 激情综合激情| 美女脱光内衣内裤视频久久网站| 亚洲成色精品| 亚洲一区二区三区在线视频| 欧美视频一区二| 欧美与黑人午夜性猛交久久久| 久久婷婷av| 一区二区三区视频在线播放| 欧美日韩另类综合| 校园春色国产精品| 免费视频久久| 最新国产乱人伦偷精品免费网站 | 久久久亚洲国产美女国产盗摄| 久久久亚洲高清| 1024欧美极品| 欧美精品午夜| 欧美影院成人| 91久久综合| 欧美在线www| 亚洲区中文字幕| 国产精品男女猛烈高潮激情| 久久精品一区二区国产| 亚洲国产精品电影| 欧美亚洲三级| 日韩一级网站| 国产在线视频欧美一区二区三区| 欧美成人网在线| 性欧美超级视频| 亚洲精品国产系列| 国产日韩精品在线播放| 亚洲国产欧美日韩精品| 亚洲免费在线视频| 1024国产精品| 国产精品一区在线观看你懂的| 免费在线欧美视频| 亚洲免费在线精品一区| 亚洲国产综合91精品麻豆| 久久精品国产一区二区三| 9久re热视频在线精品| 好看的av在线不卡观看| 欧美日韩综合一区| 久热成人在线视频| 午夜日本精品| 亚洲午夜精品福利| 亚洲美女网站| 亚洲欧洲一区二区三区在线观看| 久久久久99| 亚洲欧美在线网| 亚洲四色影视在线观看|