• <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>
            算法學社
            記錄難忘的征途
            posts - 141,comments - 220,trackbacks - 0

            題目描述:

               求一個字符串的最長回文串。串長度小于110,000。

            吐槽:

                1. O(nlogn)構造后綴數組超時... O(n)的不會... 是我寫挫了 ????
                2. 拖了一年多才重新捉這題... 該打......

            算法分析:

                直接上Manacher算法,詳解在這里。
                為什么P[i] = min(P[id - (i - id)], (P[id] + id) - i) 呢? 自己畫一畫就知道了......

             1 #include<iostream>
             2 #include<cstdio>
             3 #include<cstdlib>
             4 #include<cassert>
             5 #include<cstring>
             6 using namespace std;
             7 #define re(i,n) for(int i = 0;i<n;i++)
             8 const int N = 250000;
             9 template <typename T> inline void chkmax(T &a,const T b) {if(a<b) a = b;}
            10 int num[N],P[N];
            11 char ch[N];
            12 int main(){
            13     while(~scanf("%s",ch)){
            14         int n = strlen(ch);
            15         int N = 1;
            16         num[0] = 300;
            17         re(i,n) {
            18             num[N++]=99;
            19             num[N++]=ch[i]-'a'; 
            20         }
            21         num[N++]=99;
            22         num[N++]=100;
            23         int id =0 ,mx = 1,ans = 0;
            24         for(int i=1;i<N;i++){
            25             if(mx > i) {
            26                 P[i] = min(P[2*id - i], mx - i);
            27             }
            28             else P[i] = 1;
            29             for(;num[i+P[i]]==num[i-P[i]];P[i]++);
            30             if(i+P[i]-1 >= mx){
            31                 mx = i + P[i]-1;
            32                 id = i;
            33             }
            34             chkmax(ans,P[i]-1);
            35         }
            36         cout<<ans<<endl;
            37     }
            38 }
            39 
            posted on 2012-05-02 21:26 西月弦 閱讀(519) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告 、經典題目
            精品久久久久久| 中文成人无码精品久久久不卡 | 伊人丁香狠狠色综合久久| 久久亚洲国产精品五月天婷| 日韩久久久久久中文人妻| 婷婷综合久久狠狠色99h| 国产呻吟久久久久久久92| 亚洲国产精品无码久久| 亚洲狠狠综合久久| 一级做a爰片久久毛片毛片| 久久久无码一区二区三区| 大香伊人久久精品一区二区 | 国产精品一区二区久久精品无码| 久久久久国产日韩精品网站| 久久精品国产一区二区三区日韩| 久久精品国产亚洲7777| 丰满少妇高潮惨叫久久久| 亚洲午夜精品久久久久久app| 久久精品黄AA片一区二区三区| 国产精品伦理久久久久久| 青草国产精品久久久久久| 欧美日韩中文字幕久久久不卡| 久久精品国产福利国产琪琪| 99久久成人国产精品免费| 久久99久久99小草精品免视看| 少妇熟女久久综合网色欲| 久久精品一区二区影院 | 中文字幕久久亚洲一区| 国产三级观看久久| 伊人色综合久久天天| 俺来也俺去啦久久综合网| 久久人人爽人人人人爽AV| 国产毛片欧美毛片久久久| 亚洲国产欧美国产综合久久 | 精品无码久久久久久久久久| 麻豆AV一区二区三区久久 | 狠狠色伊人久久精品综合网| 久久久国产精品亚洲一区| 99久久国产宗和精品1上映| 中文无码久久精品| 亚洲精品午夜国产VA久久成人|