专栏文章
字符串基础 III
个人记录参与者 1已保存评论 0
文章操作
快速查看文章及其快照的属性,并进行相关操作。
- 当前评论
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @min76suh
- 此快照首次捕获于
- 2025/12/01 21:41 3 个月前
- 此快照最后确认于
- 2025/12/01 21:41 3 个月前
对于后缀数组 SA 的倍增做法,建议 分钟写完。
因为这是最稳妥的
因为这是最稳妥的
后缀树
将所有后缀放入字典树,得到后缀树。
把两个后缀,得到的就是它们的 LCP。
就是 SA 数组中相邻的两个串在树中 LCA 的深度。
理解可以理解为如果这棵树是自然生长的树,height 就是数论的深度。
就是 SA 数组中相邻的两个串在树中 LCA 的深度。
理解可以理解为如果这棵树是自然生长的树,height 就是数论的深度。
height 数组
( 表示 rank)
见贤思齐
- 每个后缀看比其大的第一个,即为见贤。
- 然后再直接匹配就是 思齐。
求解 height
朴素暴力
直接暴力匹配
判断最长公共前缀长度是 。
,但是在随机数据跑的飞快。
,但是在随机数据跑的飞快。
二分+哈希
判断最长公共前缀长度是 。
线性
根据引理 。
故事
向 抄作业,一定能抄到
应用
后缀 LCP
使用简化问题证明,使用 RMQ 算法实现。
子串 LCP
对两个后缀求 LCP,然后截断。
不同子串数量
考虑简化问题:
结合以下就是
发现对于
然后推广就能得到。
abcde 全不同aaaaa 全同结合以下就是
abcda:发现对于
abcde 中的 多出一个 。然后推广就能得到。
最长重复字串
排序以后物以类聚
思考
最长:二分
哈希:物以类聚 字串:后缀的前缀
哈希:物以类聚 字串:后缀的前缀
二分+哈希
二分
提取所有长度为 的字串,然后哈希判重。
提取所有长度为 的字串,然后哈希判重。
height
最长不重叠字串
二分+哈希
经仍然可解。
height
二分答案
例1
题意
给定一个序列。
最长重复 次的字串最长长度。
显然哈希可解,但是学 height。
思考
- 排序以后物以类聚
- 简化问题(,)
结果
对每个长度为 的滑动窗口求 ,最后的结果求
例2
相关推荐
评论
共 0 条评论,欢迎与作者交流。
正在加载评论...