poj2406 Power Strings (KMP)

来源:互联网 发布:宠物托运软件 编辑:程序博客网 时间:2024/05/11 05:00

这题跟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;}


1 2