KMP 撸完总结

前段时间d哥让我帮忙搞个特征码扫描的接口。然后就看了下ac自动机,进而免不了KMP了。以前搞过,后又忘了,现在用自己理解,自己写出来。这样可能记忆会更深。

-----------------------------------------------------------华丽的分割线-----------------------------------------------------------------------

KMP用来解决单字符串匹配问题。

暴力的方法: 

假设源串是S,模式串为P

i=0,j=0;

ans=0;
while(i<pLen&&j<sLen){
if(s[j]==p[i]){
i++,j++;
}
else{
i=0;
j=j-i+1;
}
if(i==pLen)
ans++;

}

不用说,小学生都写得出来,O(n*m)

每次比较的时候,当到达某个位置失配时,暴力的方式是重头来。KMP的做法是,将模式串调整至合适位置,在源串失配的位置接着进行比较。(模式串与源串比较过后,可以根据模式串的最长前后缀,产生一个next数组)

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值