• <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 最長(zhǎng)遞增字串的單調(diào)性?xún)?yōu)化

            好久不動(dòng)題目了,今天動(dòng)了一題,忒背運(yùn),死都TLE,想了想,算法復(fù)雜度沒(méi)問(wèn)題啊,n=100000,nlogn的算法拼1S的RP咋崩潰的。。后來(lái)想起了無(wú)敵的POJ超級(jí)慢速set,無(wú)奈,不想改,到處搜有這題的OJ,TOJ上跑了下,10MS。。汗。。下載數(shù)據(jù)數(shù)據(jù)來(lái)看了看,就是12組,就是本地debug也不會(huì)TLE啊。。沒(méi)辦法。。
            不發(fā)牢騷了,說(shuō)說(shuō)這題的方法吧。
            一般的最長(zhǎng)遞增字串用n^2做很好做,就是dp[i]=max{dp[j]+1,height[j]<height[i]},這題可以用單調(diào)隊(duì)列做優(yōu)化,但是和普通的單調(diào)隊(duì)列不同,要借助平衡樹(shù)
            首先,我們知道,要維護(hù)這樣一個(gè)單調(diào)隊(duì)列,當(dāng)height[i]<height[j]時(shí),要有dp[i]<dp[j],否則的話(huà),status{(j,height[j])}這個(gè)狀態(tài)以后不會(huì)推得最優(yōu)解,可以刪除。這題麻煩就麻煩再height不是個(gè)單調(diào)的函數(shù),隨著i的增大(就是沿著DP方向計(jì)算)時(shí),height不能保證也是遞增的,木有辦法,只能維護(hù)一個(gè)平衡樹(shù)那樣的東西。
            那么更新過(guò)的DP方程就是
            dp[i]=dp[j]+1,j為滿(mǎn)足height[j]<height[i]的最后一個(gè)元素
            然后更新單調(diào)隊(duì)列的策略是把當(dāng)前決策加入單調(diào)隊(duì)列里,然后往后刪除dp[i]>=dp[j]并且height[i]<height[j]的statue{j}。
            每個(gè)元素最多入隊(duì)一次,出隊(duì)一次,所以總得復(fù)雜度o(nlogn)
            我是全部用set實(shí)現(xiàn)的,輕松好省
             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 閱讀(305) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): DP

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

            導(dǎo)航

            統(tǒng)計(jì)

            公告

            統(tǒng)計(jì)系統(tǒng)

            留言簿(1)

            隨筆分類(lèi)(227)

            文章分類(lèi)(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            久久亚洲sm情趣捆绑调教| 欧美一区二区三区久久综| 久久久久久免费视频| 日韩欧美亚洲综合久久影院d3| 久久久久久精品成人免费图片 | 一本综合久久国产二区| 麻豆精品久久久一区二区| 久久棈精品久久久久久噜噜| 亚洲国产精品无码久久久蜜芽| 亚洲а∨天堂久久精品9966| 婷婷久久综合| 99久久综合国产精品免费| 久久这里的只有是精品23| 97精品伊人久久大香线蕉| 亚洲精品99久久久久中文字幕| 亚洲精品久久久www| 亚洲国产一成久久精品国产成人综合 | 无码伊人66久久大杳蕉网站谷歌 | 久久亚洲国产精品一区二区| 久久九九全国免费| 一本久久久久久久| 久久精品中文字幕第23页| 亚洲人AV永久一区二区三区久久| 亚洲精品乱码久久久久久不卡| 日本亚洲色大成网站WWW久久| 亚洲天堂久久久| 久久无码人妻一区二区三区午夜| 久久99国产精品99久久| 久久综合九色欧美综合狠狠| 国产精品久久久久蜜芽| 久久国产色AV免费看| 久久精品国产黑森林| 亚洲精品乱码久久久久久中文字幕| 久久精品亚洲日本波多野结衣| 青草影院天堂男人久久| 2021国产精品午夜久久| 99久久精品国产高清一区二区| 欧美一级久久久久久久大| 国内精品久久久久影院一蜜桃| 久久久久亚洲AV无码专区网站| 欧美一区二区三区久久综合 |