点击打开链接
//求循环次数
#include <iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
using namespace std;
const int maxn=1e6+5;
char T[maxn];
int m;
void Getnext(int next[])
{
int i=0,j=next[0]=-1;
m=strlen(T);
while(i<m)
{
if(j==-1||T[i]==T[j])
{
i++;
j++;
next[i]=j;
}
else j=next[j];
}
}
int main()
{
while(scanf("%s",T)!=EOF)
{
if(T[0]=='.') break;
int next[maxn];
Getnext(next); //得到next数组
int k=1;
if(m%(m-next[m])==0)
k=m/(m-next[m]);
printf("%d\n",k);
}
return 0;
}
poj 2406
最新推荐文章于 2024-07-11 21:13:07 发布