#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
int next[1000005];
int n;
void Next(char T[])
{
int i=0,j=-1;
next[0]=-1;
while(i<n)
{
if(j==-1||T[j]==T[i])next[++i]=++j;
else j=next[j];
}
}
int main()
{
char T[1000005];
int kase=0;
while(~scanf("%d",&n)&&n!=0)
{
scanf("%s",&T);
Next(T);
printf("Test case #%d\n",++kase);
for(int i=2;i<=n;i++)
{
if(next[i]>0&&i%(i-next[i])==0)printf("%d %d\n",i,i/(i-next[i]));
}
printf("\n");
}
return 0;
}
POJ—1961 Period
最新推荐文章于 2019-08-31 11:05:30 发布
本文详细解析了POJ题目1961 Period的解题思路,利用KMP算法求字符串周期性的特点,通过构建next数组进行高效匹配。文章提供了完整的C++代码实现,包括next数组的构建和主函数流程,适用于算法竞赛和字符串匹配学习。

5万+

被折叠的 条评论
为什么被折叠?



