编程之美3.1——字符串移位包含的问题(KMP算法)

问题:

给定两个字符串s1和s2,要求判定s2是否能够被s1做循环移位得到的字符串包含。


解法:

我们在对s1进行循环移位时,保留前面移走的数据,会发现只要将s1复制一份接在后面就能够包含匹配的所有情况。然后只要在s1中查找s2的位置就可以了,我们使用KMP算法在时间O(m+n)内就能够找出这个位置。

KMP算法还是一个比较难理解的算法之一,它的改进在于每当一趟匹配过程中出现字符比较不等时,不需回溯i指针,而是利用已经得到的“部分匹配”的结果将模式串向右“滑动”尽可能远的一段距离后,继续进行比较。


模式串T开头的串被称为前缀子串(下图字符串1...f(k-1)-1表示一个前缀子串),在T中第k个字符左边的子串被称为位置k的左子串(下图字符串k-f(k-1)...k-2表示与该前缀子串相匹配的位置k-1的左子串)。这里我们用动态规划的思路实现这个算法,在形式上与书上的实现方式相差比较大,但效率是一样,并且会更好理解和记忆

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值