kmp算法思想

BF算法缺陷,进行了很多次无效的匹配操作(明知结果不可能匹配成功的情况的操作),

让匹配过程中,主串中i不用回退,只返回子串的j值就行。

不用匹配前缀,因为后缀相同,公共前缀肯定相同。

KMP算法的核心思想,就是字符匹配失败后,主串的i不用做回退操作,只回退子串的j,

由于在任意一个字符匹配时,都有可能匹配失败,所以KMP算法的关键是就是给子串计算出一个next数组,里面存储的是当时字符匹配失败后,j要回退的位置,同理,也就是存储当前字符前面的子串的公共前后缀的长度。

next数组的长度是子串长度。

代码如下:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值