码迷,mamicode.com
首页 > 其他好文 > 详细

HDU 1358 Period (KMP)

时间:2014-08-06 15:01:01      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:c++   hdu   kmp   算法   字符串   

这道题对更加深入地理解next数组有很大帮助。

基本思路:

        字符编号从0开始,那么if(i%(i-next[i])==0),则i前面的串为一个轮回串,其中轮回子串出现i/(i-next[i])次。

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1358

#include<stdio.h>
int n,next[1000000];
char p[1000000];
void getnext()
{
   int k=0,j=1;
   next[0]=-1;next[1]=0;
   while (j<n)
     {
       if (k==-1||p[j]==p[k])
        {
          k++;j++;
          next[j]=k;
        }
       else k=next[k];
     }
}
void kmp()
{
    int i,t;
    for(i=2;i<=n;i++)
    {
        t=i-next[i];
        if(i%t==0&&i/t>1)  printf("%d %d\n",i,i/t);
    }
}
int main()
{
    int i,num=0;
    while (scanf("%d",&n)&&n>0)
    {
        scanf("%s",p);
        printf("Test case #%d\n",++num);
        getnext();
        kmp();
        printf("\n");
    }
    return 0;
}


HDU 1358 Period (KMP),布布扣,bubuko.com

HDU 1358 Period (KMP)

标签:c++   hdu   kmp   算法   字符串   

原文地址:http://blog.csdn.net/yzj577/article/details/38398953

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!