点击打开链接
#include <iostream>
#include<cstdio>
using namespace std;
const int maxn=1e6+5;
int m;
char T[maxn];
void Getnext(int next[])
{
int i=0,j=next[0]=-1;
while(i<m)
{
if(j==-1||T[i]==T[j])
{
i++;
j++;
next[i]=j;
}
else j=next[j];
}
}
int main()
{
int kase=0;
while(scanf("%d",&m)==1&&m)
{
scanf("%s",T);
int next[maxn];
Getnext(next); //得到next数组
printf("Test case #%d\n",++kase);
for(int i=2;i<=m;i++)
{
int k=i-next[i];
if(i%k==0&&i/k>1) printf("%d %d\n",i,i/k);
}
printf("\n");
}
return 0;
}
hdu 1358
最新推荐文章于 2020-02-07 11:05:28 发布