字符串算法_Z 函数_扩展 KMP
原文:https://oi-wiki.org/string/z-func/
定义:z[i] 定义为 s[i~n-1] 与 s 的最长公共前缀长度
由 https://www.cnblogs.com/kingbuffalo/p/16186634.html 所讲
很多字符串算法都是应用 借助之前的计算好的答案来加速计算新的答案。
设 z[0~i] 已算好
现在求 z[i+1] ,那么,如果z[0~i]有一点x值能覆盖 i+1 ,
则证明 z[i+1] 的值 与 s[i-x] == s[i+1] ,如果范围合理,则:z[i+1] = z[i-x];
应用
- 匹配所有子串
- 本质不同子串数
- 字符串整周期
核心算法
vector<int> z_function(string s) {
int n = (int)s.length();
vector<int> z(n);
for (int i = 1, l = 0, r = 0; i < n; ++i) {
if (i <= r && z[i - l] < r - i + 1) {
z[i] = z[i - l];
} else {
z[i] = max(0, r - i + 1);
while (i + z[i] < n && s[z[i]] == s[i + z[i]]) ++z[i];
}
if (i + z[i] - 1 > r) l = i, r = i + z[i] - 1;
}
return z;
}
习题: poj2752 http://poj.org/problem?id=2752
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构