题意:
求循环节出现的次数
例:ababab ab为循环节,出现三次
思路:
最小循环节长度为m: m=n-nxt[n]
判断是否全由循环节组成的条件:len%m==0
特例:aabaabaa
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=1000010;
int nxt[maxn];
char s[maxn];
int len;
void getnext()
{
int i,j;
i = 0;
j = nxt[0] = -1;
while(i<len)
{
if(j==-1 || s[i]==s[j])
{
i++,j++;
nxt[i] = j;
}
else
j = nxt[j];
}
}
int main()
{
while(~scanf("%s",s) && s[0]!='.')
{
len = strlen(s);
getnext();
int m = len-nxt[len];
if(len%m==0)
printf("%d\n",len/m);
else
printf("1\n");
}
return 0;
}