• <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類,判斷是否相等就是判斷在此數(shù)之前大于這個數(shù)字的數(shù)字個數(shù)、等于這個數(shù)字的數(shù)字個數(shù)以及小于這個數(shù)字的數(shù)字個數(shù)是否均相等。接下來的過程就類似KMP的匹配了。
            另外,KMP nxt數(shù)組本質(zhì)是最長后綴=最長前綴,同時要求后綴不能為整個字符串。好久不寫KMP,竟然犯了個糊涂的事情,nxt數(shù)組里算出來竟然是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 閱讀(274) 評論(0)  編輯 收藏 引用 所屬分類: string algorithm

            <2010年11月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統(tǒng)計

            公告

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

            留言簿(1)

            隨筆分類(227)

            文章分類(2)

            OJ

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            国产精品一久久香蕉国产线看观看| 一本色道久久88加勒比—综合| 91精品无码久久久久久五月天 | 久久久久亚洲AV成人网人人网站| 中文字幕久久欲求不满| 久久久久夜夜夜精品国产| 亚洲国产精久久久久久久| 一级做a爱片久久毛片| 天天爽天天爽天天片a久久网| 国产精品久久久久aaaa| 国产精品久久久久久久久| 久久九九精品99国产精品| 国产精品久久久久无码av| 日本一区精品久久久久影院| 国产69精品久久久久99| 91久久福利国产成人精品| 久久亚洲色一区二区三区| 久久中文字幕人妻熟av女| 亚洲人成精品久久久久 | 久久99久国产麻精品66| 久久久噜噜噜www成人网| 欧美伊香蕉久久综合类网站| 久久精品国产精品亜洲毛片| 久久99九九国产免费看小说| 久久久精品人妻一区二区三区蜜桃| 欧美牲交A欧牲交aⅴ久久| 久久亚洲国产精品一区二区| 三级韩国一区久久二区综合| 性欧美丰满熟妇XXXX性久久久| 久久99精品久久久久久久不卡| 国产成人综合久久久久久| 伊人情人综合成人久久网小说| 狠狠色丁香久久婷婷综合五月| 国产高潮久久免费观看| 久久www免费人成看片| 久久av高潮av无码av喷吹| 久久国产精品久久国产精品| 国产成人精品综合久久久| 77777亚洲午夜久久多人| 久久国产精品免费一区二区三区| 久久精品中文字幕一区|