标签:
题目链接:http://acm.fzu.edu.cn/problem.php?pid=1901
给你一个字符串 s 求出所有满足s[i] == s[i+p] ( 0 < i+p < len )的 p ;
kmp中Next[i] 表示前i个字符的前缀和后缀的最大匹配 s[0--x] == s[i-x-1 --- i] ;
下面是看别人的解释:
#include<stdio.h> #include<string.h> #include<algorithm> #include<stdlib.h> using namespace std; const int N = 1e6+7; char s[N]; int Next[N], ans[N]; void GetNext(char a[], int n) { int i=0, j=-1; Next[0] = -1; while(i<n) { if(j==-1 || a[i]==a[j]) Next[++i] = ++j; else j = Next[j]; } } int main() { int T, t=1, k, len; scanf("%d", &T); while(T--) { scanf("%s", s); len = strlen(s); GetNext(s, len); k = 0; for(int j=len; j>0; j=Next[j]) ans[k++] = len - Next[j]; printf("Case #%d: %d\n", t++, k); for(int i=0; i<k; i++) printf("%d%c", ans[i], i==k-1?‘\n‘:‘ ‘); } return 0; }
标签:
原文地址:http://www.cnblogs.com/zhengguiping--9876/p/4846632.html