最简单的KMP算法求next数组值的方法

本文依照严蔚敏串的数据结构(C语言版本)总结的方法:

next数组的求解方法是:

注意:1.   j的下标识从0开始排的

                2.  规定next[0]=-1,next[1]=0

                  
j              0  1  2  3  4  5  6  7 

P             a  b  a  a  b  c  a  c

next       -1  0  ?

next[0],next[1]前两个直接写;

求next[j=2],则先将P[2-1]=b和P[next[2-1]]=P[0]=a比较,不相等,则向前,P[next[2-2]]=P[-1],因为到达-1,所以next[j]=0。

j              0  1  2  3  4  5  6  7 

P             a  b  a  a  b  c  a  c

next       -1  0  0  ?

求next[j=3],先将P[3-1]=a和P[next[3-1]]=P[0]=a比较,相等,则next[3]=0+1=1

j              0  1  2  3  4  5  6  7 

P             a  b  a  a  b  c  a  c

next       -1  0  0  1  ?

法1:求next[j=4],先将P[4-1]=a和P[next[4-1]]=P[1]=b比较,不相等,则向前,P[next[4-2]]=P[0]=a=P[4-1],所以next[4]=next[4-2]+1=0+1=1。

法2:求next[j=4],先将P[4-1]=a和P[next[4-1]]=P[1]=b比较,不相等,此时记住p[next[4-1]]=P[1]=a的next的数组的值0,即next[p[1]]=0,比较P[4-1]=a与P[1]=b,不相等,此时记住P[1]的next数组的下标0,比较P[4--1]=a与P[0]=a,不相等,但时此时P[0]的下标为-1,比较结束,直接将P[4]的next值写为0;

j              0  1  2  3  4  5  6  7 

P             a  b  a  a  b  c  a  c

next       -1  0  0  1  1  ?

求next[5],先将P[5-1]=b和P[next[5-1]]=b比较,相同,则next[5]=next[5-1]+1=2。

j            0  1  2  3  4  5   6  7 

P           a  b  a  a  b  c  a  c

next     -1  0  0  1  1   2  ?

求next[6],先将P[6-1]=c和P[next[6-1]]=a比较,不相同,则向前,比较P[6-1]=c和P[next[6-2]]=b不相同,再比较P[6-1]=c和P[next[6-3]]=b不相同,再比较P[6-1]=c和P[next[6-4]]=a不相同,再比较P[6-1]=c和P[next[6-5]]=a不相同,再比较P[6-1]=c和P[next[6-6]]=P[-1]结束比较,next[6]=0.

 

j              0  1  2  3  4  5   6  7 

P             a  b  a  a  b  c  a  c

next       -1  0  0  1  1   2  0  ?

求next[7],先将P[7-1]=a和P[next[7-1]]=a相同,所以next[7]=next[7-1]+1=0+1=1.

next数组求值完毕。

j              0  1  2  3  4  5   6  7 

P             a  b  a  a  b  c  a  c

next       -1  0  0  1  1   2  0  1

 

禁止转载,本文借鉴的博客:

https://blog.csdn.net/LawGeorge/article/details/78701848

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值