KMP算法

字符串快速匹配 的算法——KMP算法。

     得意对next数组的理解。 next[j]表明当模式中第j个元素与主串中的第i个元素不能匹配时,模式串中需要新和主串中该元素进行比较的字符在模式串中的位置。

    1当模式串中的第一个元素就不和主串中的第i 个元素匹配,则将模式串的第一个元素与主串中的第i+1个元素进行重新比较。

    2当模式串的第j(j>1)个元素与主串中的第i个元素不匹配时,若看模式串中前j-1个元素,找出其中最长的前缀与后缀,长度为k-1。则此时next[j]=k。(特殊的,若不存在相同的前缀与后缀,长度为0,则next[j]=1。)

   得意next数组的求法

      next函数值仅取决于模式串的本身。

      递推的思想

     即已知next[j]=k,求next[j+1],分为两种情况

       1.当模式串中是第k个元素与模式串中的第j个元素相同时,next[j]=k+1;

       2.当模式串中的第k个元素与模式串中的第j个元素不相同时,将此时的模式串看成是一个主串。只需将模式串中的第k个元素与模式串(也成为主串)中的第j个元素比较,若相等,则next[j+1]=next[k]+1;若第k个元素与第j个元素仍不相等,再继续比较模式串中第next[k]个元素与第j个元素是否相同,若相同,则next[j+1]=next[next[k]],当next[k']=0时,next[j+1]=1;

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值