KMP查询算法的匹配串的前缀后缀相同的最大长度

一、KMP算法的作用

查询复杂度是O(n+m),其中n是主字符串长度,m是匹配串的长度。

二、字符串的前缀和后缀

(一)前缀

指的是字符串从第1个字符串开始,每次截取连续字符串的操作。

例如字符串"ABC"的前缀有下列情况:

"A"、"AB"、"ABC"。

(二)后缀

指的是从第1个字符开始,每次截取连续字符串到最后1个字符的操作。

例如字符串"ABC"的后缀有下列情况:

"ABC"、"BC"、"C"。

三、匹配串的前缀和后缀相同

简单的说:就是把前缀和后缀拿来比较,有相同的就记录前缀或者后缀的长度。

案例(避免选择整个字符串为前缀和后缀):

以匹配串"ABAB" 为例:

比较1个字符:前缀"A"和后缀"B"不相同。

比较2个字符:前缀"AB"和后缀"AB"相同,记录前缀长度是2个字符。

比较3个字符:前缀"ABA"和后缀"BAB"不相同。

四、KMP比较的思路

(一)预处理,求得匹配串每个字符前面的前缀和后缀相同的最长长度。

默认值是0,也就是从匹配串的第1个字符开始比较。

(二)按顺序从第1个位置比较主串和匹配串的对应字符

1、如果对应位置的字符相同,去下一个位置比较。

2、如果比较到匹配串的末尾,代表匹配成功。

3、如果对应字符不相等,就把匹配串跳转到前缀后缀相同的长度,继续比较。

总之,前面有比较过并且相同的,就不需要从头开始比较了。

相关推荐
CSharp精选营4 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假7 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠8 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦15 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠16 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾16 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82116 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q16 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒16 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记16 天前
单项不带头不循环链表
数据结构·链表