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

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

最長上升子序列 O(nlogn)解法 (轉)

Posted on 2012-11-30 17:44 鑫龍 閱讀(14942) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構與算法

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

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

   設dp[i]表示以i為結尾的最長遞增子序列的長度,則狀態轉移方程為:

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

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

   考慮兩個數a[x]和a[y],x<y且a[x]<a[y],且dp[x]=dp[y],當a[t]要選擇時,到底取哪一個構成最優的呢?顯然選取a[x]更有潛力,因為可能存在a[x]<a[z]<a[y],這樣a[t]可以獲得更優的值。在這里給我們一個啟示,當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]在計算過程中單調不升;           

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

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

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

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

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

 

  1. /** 
  2. 最長遞增子序列O(nlogn)算法: 
  3. 狀態轉移方程: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. 首先根據f[]值分類,記錄滿足f[t]=k的最小的值a[t],記d[k]=min{a[t]},f[t]=k. 
  6.     1.發現d[k]在計算過程中單調不上升 
  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] 原始數據  
  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)解法 (轉)  回復  更多評論   

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>
            亚洲视频在线播放| 欧美日韩网址| 亚洲丝袜av一区| 欧美日韩国产三区| 一区二区三区欧美成人| 亚洲专区欧美专区| 欧美精品一区视频| 久久精品国产99| 精品二区视频| 欧美精品麻豆| 午夜视频在线观看一区| 蜜桃av一区二区| 中文av字幕一区| 国产亚洲精品一区二区| 欧美成人午夜影院| 亚洲午夜精品| 亚洲成色最大综合在线| 亚洲乱码国产乱码精品精| 国产精品成人国产乱一区| 欧美在线一二三四区| 亚洲人成人99网站| 久久久夜夜夜| 亚洲一区二区三区高清不卡| 激情久久久久久| 国产精品国内视频| 久久一区免费| 亚洲欧美视频在线观看| 欧美高清在线观看| 性久久久久久久久久久久| 亚洲精品免费看| 国产一区二区三区在线观看免费视频| 欧美肥婆bbw| 久久琪琪电影院| 亚洲欧美日韩一区二区三区在线观看 | 亚洲国产另类 国产精品国产免费| 在线视频日韩| 在线播放国产一区中文字幕剧情欧美| 欧美日韩情趣电影| 欧美激情久久久| 蜜月aⅴ免费一区二区三区| 久久国内精品自在自线400部| 亚洲深夜福利网站| 一本色道久久综合亚洲精品高清| 欧美成人午夜视频| 美日韩精品免费| 久久久久久夜| 玖玖综合伊人| 久久一区二区三区国产精品| 欧美制服丝袜第一页| 亚洲欧美日韩电影| 亚洲综合色婷婷| 亚洲一区欧美激情| 亚洲伊人一本大道中文字幕| 久久精品日韩欧美| 久久另类ts人妖一区二区| 亚洲欧美日韩一区| 亚洲天堂av在线免费| 亚洲欧洲精品一区二区| 亚洲国产精品久久久| 今天的高清视频免费播放成人| 国产三级欧美三级日产三级99| 国产乱理伦片在线观看夜一区| 国产精品女同互慰在线看| 国产精品呻吟| 韩国精品久久久999| 一区二区在线视频播放| 国外成人在线视频网站| 一区二区三区亚洲| 亚洲国产一区二区三区a毛片| 亚洲乱码国产乱码精品精98午夜| 亚洲国产成人tv| 亚洲美女中文字幕| 亚洲一区二区三区免费观看| 欧美一区免费视频| 久久视频国产精品免费视频在线| 美女国产精品| 最新日韩精品| 亚洲婷婷国产精品电影人久久| 中文网丁香综合网| 久久成人av少妇免费| 老巨人导航500精品| 欧美日韩精品免费观看视一区二区 | 亚洲制服欧美中文字幕中文字幕| 亚洲免费视频一区二区| 久久免费精品视频| 亚洲激情自拍| 午夜在线视频一区二区区别| 男同欧美伦乱| 国产精品一区二区男女羞羞无遮挡| 国产视频亚洲| 亚洲最新视频在线播放| 欧美一区二区三区免费视| 免费在线播放第一区高清av| 一区二区三区视频观看| 久久一区亚洲| 国产精品嫩草影院av蜜臀| 亚洲国产乱码最新视频| 亚洲欧美精品在线| 欧美激情乱人伦| 欧美一级午夜免费电影| 欧美日韩三级| 91久久综合| 久久久国产视频91| 一区二区欧美亚洲| 免费视频久久| 亚洲精品乱码久久久久久蜜桃麻豆| 在线视频欧美精品| 免费欧美在线视频| 国产日韩欧美一区二区| 99re6热在线精品视频播放速度| 欧美一区二区日韩| 亚洲精品四区| 久久综合激情| 国产一区二区三区自拍| 亚洲男人av电影| 亚洲毛片一区| 欧美高清在线观看| 亚洲国产精品成人久久综合一区| 欧美在线www| 亚洲在线观看免费| 国产精品久久二区| 夜夜嗨av一区二区三区免费区| 欧美sm重口味系列视频在线观看| 午夜精品免费在线| 国产欧美在线视频| 欧美在线1区| 亚洲综合视频一区| 国产乱人伦精品一区二区 | 久久九九99视频| 国内精品免费午夜毛片| 久久精品国语| 午夜一区二区三区在线观看| 国产精品区一区二区三| 亚洲欧美日韩国产综合| 亚洲欧美三级在线| 一区二区三区在线视频播放| 美日韩精品视频免费看| 免费久久久一本精品久久区| 亚洲欧洲日夜超级视频| 亚洲精品国产无天堂网2021| 欧美日韩激情小视频| 午夜精品久久久久久久久久久久久 | 国产一区二区三区久久悠悠色av | 国产免费一区二区三区香蕉精| 亚洲欧美日韩精品| 欧美一级黄色录像| 在线精品国产成人综合| 亚洲国产精品免费| 欧美日韩一区二| 欧美一区二区视频在线观看| 久久成人国产精品| 亚洲肉体裸体xxxx137| 亚洲精选视频免费看| 国产精品视频午夜| 猛干欧美女孩| 欧美日韩国产在线播放| 国模精品一区二区三区| 最新成人av在线| 日韩午夜激情| 国产欧美在线观看| 亚洲激情二区| 国产欧美日本一区二区三区| 蜜桃av一区二区| 国产精品爱啪在线线免费观看| 欧美影院成人| 欧美日本三区| 性欧美精品高清| 麻豆精品视频| 欧美亚洲一区在线| 欧美a级在线| 欧美怡红院视频| 欧美精品一区在线播放| 欧美诱惑福利视频| 欧美另类视频| 久久精品一二三| 嫩草影视亚洲| 欧美在线免费视频| 欧美日韩一区二区三| 老司机免费视频一区二区三区| 欧美涩涩网站| 亚洲人成高清| 在线观看成人一级片| 亚洲自拍高清| 亚洲视频精选在线| 欧美不卡高清| 嫩草影视亚洲| 国产亚洲综合精品| 亚洲午夜性刺激影院| 一本一本久久a久久精品综合麻豆| 久久国产一区二区| 欧美中日韩免费视频| 国产精品日韩精品欧美精品| 亚洲精品久久嫩草网站秘色| 亚洲高清在线精品| 久久久久久一区| 久久网站免费| 狠狠色丁香婷婷综合久久片| 午夜激情久久久| 欧美在线www| 国产综合自拍|