kmp & exkmp 模板
kmp inline void calc_next() { // 计算next数组 a为模式串 从1开始 next[1] = 0; for (int i = 2, j = 0; i <= n; ++ i) { while (j > 0 && a[i] != a[j + 1]) j = next[j]; if (a[i] == a[j + 1]) j ++; next[i] = j; } } inline void calc_f() { // kmp b为主串 从1开始 for (int i = 1, j = 0; i <= m; ++ i) { while (j > 0 && (j == n || b[i] != a[j + 1])) j = next[j]; if (b[i] == a[j + 1]) j ++; f[i] = j; if (f[i] == n) {/* the first time */} } } exkmp // 求 a 关于 b 的后缀的最长公共前缀, Next 记录 a关于自己每个后缀的最长公共前缀, ret 记录 a 关于 b 的后缀的最长公共前缀 void ExtendedKMP(char *a, char *b, int M, int N, int *Next, int *ret) { int i, j, k; for (j = 0; 1 + j <