就是kmp求最小循环节在套一个循环,关于kmp求最小循环节请看

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 1e6 + 10;
char p[maxn];
int flag = 0, n, Next[maxn];
void makeNext() {
int i = 0, j = 0;
Next[i] = j;
for (i = 1; i < n; i++) {
while (j && p[i] != p[j]) j = Next[j - 1];
if (p[i] == p[j]) j++;
Next[i] = j;
}
}
int main() {
while (scanf("%d", &n) == 1 && n) {
scanf("%s", p);
makeNext();
if (flag++) printf("\n");
printf("Test case #%d\n", flag);
for (int i = 1; i < n; i++) {
int L = (i + 1) - Next[i];
if ((i + 1) != L && (i + 1) % L == 0) {
printf("%d %d\n", i + 1, (i + 1) / L);
}
}
}
return 0;
}