题意:
从小到大输出 字符串由循环节组成的前缀 的长度,并输出循环节的次数
思路:
求出 nxt[] 数组,从头到尾遍历一遍判断是否是由循环节组成(满足条件:i%(i-nxt[i])==0 && nxt[i]!=0 )
i-nxt[i] 为循环节的长度
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=1000010;
int nxt[maxn];
char s[maxn];
int n;
void getnext()
{
int i,j;
i = 0;
j = nxt[0] = -1;
while(i<n)
{
if(j==-1 || s[i]==s[j]) //不能用优化算法
{
i++,j++;
nxt[i] = j;
}
else
j = nxt[j];
}
}
int main()
{
int k=1;
while(~scanf("%d",&n) && n)
{
scanf("%s",s);
printf("Test case #%d\n",k++);
getnext();
for(int i=1;i<=n;i++)
{
if(i%(i-nxt[i])==0 && nxt[i]!=0)
printf("%d %d\n",i,i/(i-nxt[i]));
}
printf("\n");
}
return 0;
}