字符串的模式匹配 KMP Algorithm

本文深入探讨了KMP算法,一种用于字符串模式匹配的方法。通过实例解释了算法的运作过程,强调了‘部分匹配’表(失配函数)的重要性,该表允许算法在不重复匹配主文字符串中的字符的情况下进行线性时间搜索。文章还提供了C++和Java的实现代码,展示如何创建和使用部分匹配表。
摘要由CSDN通过智能技术生成

本章讨论的是基于KMP算法(KMP即Knuth-Morris-Pratt)的串的模式匹配问题,什么是模式匹配,请参考前一章字符串的模式匹配 Pattern Searching

 

查找算法实例

让我们用一个实例来演示这个算法。在任意给定时间,本算法被两个整数m和i所决定:

  • m代表主文字符串S内匹配字符串W的当前查找位置,
  • i代表匹配字符串W当前做比较的字符位置。

图示如下:

 

我们从W与S的开头比较起。我们比对到S[3](=' ')时,发现W[3](='D')与其不符。接着并不是从S[1]比较下去。我们已经知道S[1]~S[3]不与W[0]相合。因此,略过这些字符,令m = 4以及i = 0。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Storm-Shadow

你的鼓励将是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值