• <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>

            pku3903 最長遞增字串的單調性優化

            好久不動題目了,今天動了一題,忒背運,死都TLE,想了想,算法復雜度沒問題啊,n=100000,nlogn的算法拼1S的RP咋崩潰的。。后來想起了無敵的POJ超級慢速set,無奈,不想改,到處搜有這題的OJ,TOJ上跑了下,10MS。。汗。。下載數據數據來看了看,就是12組,就是本地debug也不會TLE啊。。沒辦法。。
            不發牢騷了,說說這題的方法吧。
            一般的最長遞增字串用n^2做很好做,就是dp[i]=max{dp[j]+1,height[j]<height[i]},這題可以用單調隊列做優化,但是和普通的單調隊列不同,要借助平衡樹
            首先,我們知道,要維護這樣一個單調隊列,當height[i]<height[j]時,要有dp[i]<dp[j],否則的話,status{(j,height[j])}這個狀態以后不會推得最優解,可以刪除。這題麻煩就麻煩再height不是個單調的函數,隨著i的增大(就是沿著DP方向計算)時,height不能保證也是遞增的,木有辦法,只能維護一個平衡樹那樣的東西。
            那么更新過的DP方程就是
            dp[i]=dp[j]+1,j為滿足height[j]<height[i]的最后一個元素
            然后更新單調隊列的策略是把當前決策加入單調隊列里,然后往后刪除dp[i]>=dp[j]并且height[i]<height[j]的statue{j}。
            每個元素最多入隊一次,出隊一次,所以總得復雜度o(nlogn)
            我是全部用set實現的,輕松好省
             1 # include <cstdio>
             2 # include <set>
             3 using namespace std;
             4 struct node
             5 {
             6    int height,id;
             7    node(int h,int i):height(h),id(i){}
             8    bool operator<(const node &pos) const
             9    {
            10        if(height!=pos.height) return height<pos.height;
            11        else return id<pos.id;
            12    }
            13 };
            14 set<node> q;
            15 int dp[100005];
            16 int main()
            17 {
            18      int n;
            19      while(scanf("%d",&n)!=EOF)
            20      {
            21         q.clear();
            22         for(int i=0;i<n;i++)
            23         {
            24             int t;
            25             scanf("%d",&t);
            26             set<node>::iterator it=q.lower_bound(node(t,-1));
            27             int ans;
            28             if(it==q.begin())
            29               ans=1;
            30             else
            31               ans=dp[(--it)->id]+1;
            32             it=q.lower_bound(node(t,-1));
            33             if(it!=q.end()&&it->height==t) 
            34                  it=q.erase(it);
            35             while(it!=q.end()&&dp[it->id]<=ans) 
            36                  it=q.erase(it);
            37             q.insert(node(t,i)); 
            38             dp[i]=ans;
            39         }
            40         printf("%d\n",dp[q.rbegin()->id]);
            41      }
            42      return 0;
            43 }
            44 

            posted on 2012-02-09 19:33 yzhw 閱讀(315) 評論(0)  編輯 收藏 引用 所屬分類: DP

            <2012年2月>
            2930311234
            567891011
            12131415161718
            19202122232425
            26272829123
            45678910

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久婷婷国产综合精品| 2021国内久久精品| 亚洲午夜久久影院| 91精品久久久久久无码| 久久亚洲国产成人影院网站| 亚洲欧洲中文日韩久久AV乱码| 精品国产乱码久久久久久人妻 | 亚洲精品高清久久| 怡红院日本一道日本久久| 久久婷婷是五月综合色狠狠| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 亚洲午夜无码AV毛片久久| 久久香蕉国产线看观看精品yw| 国产精品成人精品久久久| 东方aⅴ免费观看久久av| 欧美国产成人久久精品| 国产一级持黄大片99久久| 久久婷婷五月综合成人D啪| 97久久精品人人做人人爽| 午夜天堂精品久久久久| 久久综合噜噜激激的五月天| 久久99亚洲综合精品首页| 久久99精品久久久久久齐齐| 国产精品久久久久影视不卡| 国产精品久久成人影院| 久久亚洲私人国产精品vA| 久久天天躁夜夜躁狠狠躁2022 | 国产午夜免费高清久久影院 | 久久66热人妻偷产精品9| 久久99精品国产麻豆宅宅| 一级a性色生活片久久无| 天天做夜夜做久久做狠狠| 久久亚洲sm情趣捆绑调教| 香蕉aa三级久久毛片| 伊人久久一区二区三区无码| 老司机午夜网站国内精品久久久久久久久 | 久久久久久国产精品无码下载| 伊人久久国产免费观看视频| 亚洲人成精品久久久久| 亚洲乱码精品久久久久..| 99精品国产99久久久久久97|