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

            pku3167 Cow Patterns KMP好題

            題意:
            K長度的模式串,N長度的主串,求多少個位置能夠匹配。
            這里模式串以及主串里的值均為rank,即15567和26678認為是匹配的。

            解法:
            對于這種rank類,判斷是否相等就是判斷在此數之前大于這個數字的數字個數、等于這個數字的數字個數以及小于這個數字的數字個數是否均相等。接下來的過程就類似KMP的匹配了。
            另外,KMP nxt數組本質是最長后綴=最長前綴,同時要求后綴不能為整個字符串。好久不寫KMP,竟然犯了個糊涂的事情,nxt數組里算出來竟然是1,2,3,4.。。無語。

            代碼:
             1 Source Code
             2 Problem: 3167        User: yzhw
             3 Memory: 24496K        Time: 813MS
             4 Language: GCC        Result: Accepted
             5 
             6     Source Code
             7 
             8     # include <stdio.h>
             9     # include <string.h>
            10     # define N 100005
            11     # define M 30
            12     int n,k,s;
            13     int cal1[N][M],cal2[N][M],nxt[N],d1[N],d2[N];
            14     int equal(int *e1,int *s1,int *e2,int *s2,int val1,int val2)
            15     {
            16         if(e1[val1-1]-s1[val1-1]==e2[val2-1]-s2[val2-1]&&
            17            (e1[val1]-e1[val1-1])-(s1[val1]-s1[val1-1])==(e2[val2]-e2[val2-1])-(s2[val2]-s2[val2-1])&&
            18            (e1[s]-e1[val1])-(s1[s]-s1[val1])==(e2[s]-e2[val2])-(s2[s]-s2[val2]))
            19         return 1;
            20         else return 0;
            21     }
            22     int main()
            23     {
            24         int i,t,j,p,total=0;
            25         //freopen("cpattern.9.in","r",stdin);
            26         //freopen("ans.txt","w",stdout);
            27 
            28         scanf("%d%d%d",&n,&k,&s);
            29         memset(cal1,0,sizeof(cal1));
            30         memset(cal2,0,sizeof(cal2));
            31         for(i=1;i<=n;i++)
            32         {
            33             scanf("%d",&t);
            34             d2[i]=t;
            35             //cal2[i][t]++;
            36             for(j=1;j<=s;j++)
            37                 cal2[i][j]+=cal2[i-1][j];
            38             for(j=t;j<=s;j++)
            39                 cal2[i][j]++;
            40 
            41         }
            42         for(i=1;i<=k;i++)
            43         {
            44             scanf("%d",&t);
            45             d1[i]=t;
            46             //cal1[i][t]++;
            47             for(j=1;j<=s;j++)
            48                 cal1[i][j]+=cal1[i-1][j];
            49             for(j=t;j<=s;j++)
            50                 cal1[i][j]++;
            51         }
            52         nxt[1]=0;
            53         for(i=2;i<=k;i++)
            54         {
            55             p=nxt[i-1];
            56             while(p&&!equal(cal1[p+1],cal1[0],cal1[i],cal1[i-p-1],d1[p+1],d1[i]))
            57                 p=nxt[p];
            58             if(equal(cal1[p+1],cal1[0],cal1[i],cal1[i-p-1],d1[p+1],d1[i])) nxt[i]=p+1;
            59             else nxt[i]=0;
            60         }
            61         p=0;
            62         for(i=1;i<=n;i++)
            63         {
            64             while(p&&!equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p=nxt[p];
            65             if(equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p++;
            66             if(p==k)
            67             {
            68                 total++;
            69                 p=nxt[p];
            70             }
            71         }
            72         printf("%d\n",total);
            73         p=0;
            74         for(i=1;i<=n;i++)
            75         {
            76             while(p&&!equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p=nxt[p];
            77             if(equal(cal1[p+1],cal1[0],cal2[i],cal2[i-p-1],d1[p+1],d2[i])) p++;
            78             if(p==k)
            79             {
            80                 printf("%d\n",i-k+1);
            81                 p=nxt[p];
            82             }
            83         }
            84         return 0;
            85     }
            86 
            87 

            posted on 2011-06-05 09:35 yzhw 閱讀(284) 評論(0)  編輯 收藏 引用 所屬分類: string algorithm

            <2010年10月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告

            統計系統

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久人人爽人人爽人人AV| 狠色狠色狠狠色综合久久 | 欧美伊人久久大香线蕉综合| 久久国产免费观看精品| 亚洲国产精品久久久久婷婷软件 | 精品欧美一区二区三区久久久 | 麻豆精品久久久一区二区| 狠狠精品久久久无码中文字幕| 性高湖久久久久久久久AAAAA| 久久久久亚洲AV成人片| 久久免费大片| 国产精品久久久久9999高清| 一日本道伊人久久综合影| 免费国产99久久久香蕉| 精品国产乱码久久久久久人妻| 国产精品久久久久影视不卡| 久久久午夜精品福利内容| 精品视频久久久久| 狠狠色丁香久久婷婷综合五月| 欧美伊人久久大香线蕉综合 | 国产精品99久久久精品无码| 精品久久久久久无码国产| 东京热TOKYO综合久久精品| 国产精品久久新婚兰兰| 久久午夜综合久久| 国产99久久久国产精品~~牛| 欧美牲交A欧牲交aⅴ久久 | 伊人久久大香线蕉无码麻豆| 精品久久久久久久久久中文字幕 | 国产午夜福利精品久久2021| 狠狠色丁香久久婷婷综合图片| 国产成人香蕉久久久久| 久久se精品一区二区| 无码人妻精品一区二区三区久久久| 看全色黄大色大片免费久久久 | 77777亚洲午夜久久多喷| 波多野结衣久久一区二区| 亚洲精品无码久久久| 亚洲国产婷婷香蕉久久久久久| 四虎亚洲国产成人久久精品| 国产精品伦理久久久久久|