KMP&拓展KMP
KMP算法
说明#
KMP算法是一种比较高效的字符串匹配算法,可以在线性时间内求出一个串在另一个串的所有匹配位置。
解析#
设模板串是 令 , 可以通过动态规划求解。
板子#
数组存在的意义:
当 串匹配到 , 串匹配到 时, 如果发现失配,可以直接令 然后继续匹配, ( 将记录如果 串匹配到 的 位置,前面有多少是已经匹配了的。)
数组的求法
算法流程:
- 初始化 ,假设 已经求出,下面求解
- 不断尝试扩展长度 , 如果扩展失败(下一个字符不相等),令 变为 , 直至 (应该从头开始匹配)
- 如果扩展成功,匹配长度 就增加 , 的值就是 。
inline void calc_next() {
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() {
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 */}
}
}
拓展KMP算法
说明#
在线性复杂度内求出一个串对于另一个串的每个后缀的最长公共前缀
解析#
假设两个串是 和 , 要求 的每个 的后缀的最长公共前缀.
我们可以先求出 与它自己的每个后缀的最长公共前缀(假设为 )。类似KMP的思想,假设我们现在要计算 的第 个字符开头的后缀,而我们已经得到了 , 我们可以找到以前的一个 使得 最大(就是匹配到的范围最大),我们可以得知 , 于是可以得到 ,即我们可以利用 的信息。
分两种情况讨论,如果 比小,则 ,否则暴力扫一次。计算 与 的后缀的最长公共前缀也是类似的方法,可以证明复杂度是线性的。
板子#
(未精简版本)
输入:求 关于 的后缀的最长公共前缀, 记录 关于自己每个后缀的最长公共前缀, 记录 关于 的后缀的最长公共前缀
void ExtendedKMP(char *a, char *b, int M, int N, int *Next, int *ret) {
int i, j, k;
for (j = 0; 1 + j < M && a[j] == a[1 + j]; ++ j);
Next[1] = j;
k = 1;
for (i = 2; i < M; ++ i) {
int Len = k + Next[k], L = Next[i - k];
if (L < Len - i) {
Next[i] = L;
} else {
for (j = max(0, Len - i); i + j < M && a[j] == a[i + j]; ++ j);
Next[i] = j;
k = i;
}
}
for (j = 0; j < N && j < M && a[j] == b[j]; ++ j);
ret[0] = j;
k = 0;
for (i = 1; i < N; ++ i) {
int Len = k + ret[k], L = Next[i - k];
if (L < Len - i) {
ret[i] = L;
} else {
for (j = max(0, Len - i); j < M && i + j < N && a[j] == b[i + j]; ++ j);
ret[i] = j;
k = i;
}
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具