前缀函数(KMP 中的 Pi 数组)
我们用
前缀函数,即
其中一个字符串的 border 表示它的某个(不等于原串的)子串,使得这个子串在原串的前缀和后缀都出现过。
显然一个字符串的 border 可能有多个,我们要求解的
在这求解
首先
如图。根据
观察第一段蓝色和最后一段蓝色,发现这又是一个
同理不难得出第三长的是
考虑顺次求解
对于一个
如果能将这个 border 的长度增加
我们可以用上面讲的方式枚举
求解
int ne[N]; // ne[i] 就是 pi[i],即 s[1...i] 的最长 border(的长度)
ne[0] = ne[1] = 0;
for (int i = 2; i <= n; ++ i ) {
int j = ne[i - 1];
while (j && s[j + 1] != s[i]) j = ne[j];
if (s[j + 1] == s[i]) j ++ ;
ne[i] = j;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效