这题跟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
原文地址:http://blog.csdn.net/yzj577/article/details/38400551