KMP算法笔记

本文深入讲解了KMP算法的工作原理及实现过程,包括next数组的构造方法及其在字符串匹配中的应用,并提供了详细的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

KMP算法笔记

关于KMP

(1)    引子:

对于2个字符串A,B,其中A为主串,B为待匹配的子串,如

i   1 2 3 4 5 6 7 8 ...

Aa b a a c c a b a b a a b c a c b a c a c ...

Ba b a a b c a c

j   1 2 3 4 5 6 7 8 ...

A[5] != B[5]时,蛮力法是从头再来,而KMP算法则不同,它采用一定的策略,调整j的位置,使得B[j] == A[i]

(2)    KMP主代码:

3)从(2)中的代码可以看出,KMP算法的关键是构造next表。

关于next

1 next[i]表示的是:

在第i个字符前面的i-1个字符里面,

从开头开始的1个字符与最后1个字符是否相等,若不是,则next[i]=0,否则继续看下面;

从开头开始的2个字符与最后2个字符是否相等,若不是,则next[i]=1,否则继续看下面;

从开头开始的3个字符与最后3个字符是否相等,若不是,则next[i]=2,否则继续看下面;

……

 

2 next数组求解思路:

1位的next值为-1,第2位的next值为0,后面求解每一位的next值时,根

据前一位进行比较。

比较策略如下:

(1)    将前一位与其(next值对应的字符)进行比较;

(2)    如果相等,则该位的next值就是前一位的next值加上1

(3)    如果不等,向前继续寻找(next值对应的字符)来与前一位进行比较;

(4)    如果最后找到,则在这个位对应的值加上1,即为所求的next值;

(5)    如果最后没有找到,那么所求next值为0

 

3 next函数如下:

KMPDFA

附:

 

 

 


 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值