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

poj2406 Power Strings (KMP)

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

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

这题跟HDU 1358 Period (KMP) 差不多,稍微修改代码就行了。

关于KMP的更多知识,请关注从头到尾彻底理解KMP(2014年8月4日版)

#include<stdio.h>
#include<string.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 t;
    t=n-next[n];
    if(n%t==0&&n/t>1)  printf("%d\n",n/t);
    else printf("1\n");
}
int main()
{
    while (scanf("%s",p)&&p[0]!='.')
    {
        n=strlen(p);
        getnext();
        kmp();
    }
    return 0;
}


poj2406 Power Strings (KMP),布布扣,bubuko.com

poj2406 Power Strings (KMP)

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

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

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