算法:next数组的求法详解

在牛客网刷题遇到了求next数组的题型,结果在学校学的没有牢记,做错了,还是要多刷题做总结啊。

我们先口述说明一下next数组的求解方法:

我们能确定next数组第一二位一定分别为01,后面求解每一位的next值时,根据前一位进行比较。
从第三位开始,将前一位与其next值对应的内容进行比较,
如果相等,则该位的next值就是前一位的next值加上1;
如果不等,向前继续寻找next值对应的内容来与前一位进行比较,
直到找到某个位上内容的next值对应的内容与前一位相等为止,
则这个位对应的值加上1即为需求的next值;
如果找到第一位都没有找到与前一位相等的内容,那么求解的位上的next值为1

下面我们具体看题理解一下:

问题:已知串S= ‘ababaaababaa ’ , 求其 Next 数值序列

解答步骤:

1.next数组第一二位一定分别为0,1:
在这里插入图片描述
2.看第三位,按照next数组求解方法。第三位a的前一位是第二位的b,b的next值是1对应内容是a,b与a不同,则继续向前寻找next值对应的内容与第二位的b进行比较。但是找到第一位都没有找到与第二位的b相等的内容,所以第三位a的next值为1,则:
在这里插入图片描述
3.看第四位的b,b的前一位a的next值1对应内容为a,相同,所以该位b的next值就是前一位a的next(第三位的a)值加上1,即为2:
在这里插入图片描述
4.看第五位a,a的前一位b的next值2对应内容为b,相等,所以第五位a的next值就是其前一位b的next值加上1,即为3:
在这里插入图片描述
5.看第六位a,a的前一位a的next值3对应内容为a,相等,所以该位a的next值就是前一位a的next值加上1,即为4:
在这里插入图片描述
6.看第七位a,a的前一位a的next值4对应内容为b,不相等,向前继续寻找next值对应的内容来与前一位进行比较,b的next值2对应的内容为b,依旧不相等,继续向前寻找,第二位b的next值1对应内容为a,相等。因为是在第二位b处实现的相等,所以第七位a的next值为第二位b的next值上加1,即为2:
在这里插入图片描述
7.看第八位b,b的前一位a的next值2对应内容为b,不相等,向前继续寻找next值对应的内容来与前一位进行比较,b的next值1对应的内容为a,相等。因为是在第二位b处实现的相等,所以第八位a的next值为第二位b的next值上加1,即为2:
在这里插入图片描述
8.看第九位,前一位b的next值2对应内容为b,相等,所以此处next值为3:
在这里插入图片描述
9.第十位同理上面第8可得,为4:
在这里插入图片描述
10.第十一位a的前一位b的next值4对应内容为b,相等,所以此处next值为5:
在这里插入图片描述
11.最后,第十二位也是同理可以得到next值位6:
在这里插入图片描述
最后我们就求解出来了,该串′ababaaababaa′的next数组为:011234223456

只要我们记住了这个规则,再多的串也是同样的求解方法,希望也能帮助大家。

  • 437
    点赞
  • 1589
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 108
    评论
评论 108
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鲲志说

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值