KMP中的next数组最通俗最详细的解析


位序        1     2     3     4     5     6     7     8
模式串      a    b    a    a    b    c    a    c
next值       0     1    1     2    2     3    1     2
nextval值    0    1    0    2    1    3    0    2

next数组的求解方法是:
1.第一位的next值为0
2.第二位的next值为1
后面求解每一位的next值时,根据前一位进行比较
3.第三位的next值:第二位的模式串为b ,对应的next值为1;将第二位的模式串b与第一位的模式串a进行比较,不相等;则第三位的next值为1
4.第四位的next值:第三位的模式串为a ,对应的next值为1;将第三位的模式串a与第一位的模式串a进行比较,相同,则第四位的next值得为2
5.第五位的next值:第四位的模式串为a,对应的next值为2;将第四位的模式串a与第二位的模式串b进行比较,不相等;第二位的b对应的next值为1,则将第四位的模式串a与第一位的模式串a进行比较,相同,则第五位的next的值为2
6.第六位的next值:第五位的模式串为b,对应的next值为2;将第五位的模式串b与第二位的模式中b进行比较,相同,则第六位的next值为3
7.第七位的next值:第六位的模式串为c,对应的next值为3;将第六位的模式串c与第三位的模式串a进行比较,不相等;第三位的a对应的next值为1,则将第六位的模式串c与第一位的模式串a进行比较,不相同,则第七位的next值为1
8.第八位的next值:第七位的模式串为a,对应的next值为1;将第七位的模式串a与第一位的模式串a进行比较,相同,则第八位的next值为2

nextval数组的求解方法是:
1.第一位的nextval值必定为0,第二位如果与第一位相同则为0,如果不同则为1;
2.第三位的next值为1,则将第三位与第一位进行比较,相同,则第三位的nextval值为0;
3.第四位的next值为2,则将第四位和第二位进行比较,不同,则第四位的next值为其next值,为2;
4.第五位的next值为2,则将第五位和第二位进行比较,相同,则第二位的next值为1,则进行将第二位与第一位进行比较,不同,则第五位的nextval值为第二位的next值,为1;
5.第六位的next值为3,则将第六位与第三位进行比较,不同,则第六位的nextval值为其next值,为3;
6.第七位的next值为1,则将第七位与第一位进行比较,相同,则第七位的nextval值为0;
7.第八位的next值为2,则将第八位与第二位进行比较,不同,则第八位的nextval值为其next值,为2;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值