算出next数组.
对于任何一个循环字串,len-next[len]必为最小循环节长度
若len%(len-next[len])==0
即为循环字串,n=len/(len-next[len])
否则输出1
代码:
#include<cstdio>
#include<cstring>
using namespace std;
const int N=1e6+;
char str[N];
int next[N],ans,len;
void make()
{
int i=,j=-;
next[i]=j;
while(i<len)
{
if(j==-||str[i]==str[j])
{
i++;
j++;
next[i]=j;
}
else
j=next[j];
}
}
int main()
{
while(~scanf("%s",str))
{
if(str[]=='.') break;
len=strlen(str);
make();
int k=next[len];
if(!(len%(len-k)))
printf("%d\n",len/(len-k));
else
printf("1\n");
}
return ;
}