利用KMP算法对该字符串处理计算出它的部分匹配表(next)
利用next求出它的循环节。
#include <cstdio>
const int maxn = 1000000 + 10;
char s[maxn];
int next[maxn];
int n;
void get_next() {
int k = 0;
next[0] = 0;
for (int q = 1; q < n; q++) {
while (k > 0 && s[q] != s[k]) {
k = next[k-1];
}
if (s[k] == s[q]) {
k++;
}
next[q] = k;
}
}
int main() {
int t = 1;
while (scanf("%d", &n) == 1 && n) {
getchar();
gets(s);
printf("Test case #%d\n", t++);
get_next();
for (int i = 0; i < n; i++) {
int len = i - next[i] + 1;
if (len < i + 1 && (i + 1) % len == 0) {
printf("%d %d\n", i + 1, (i + 1) / len);
}
}
putchar('\n');
}
return 0;
}