【题解】「NOI2014」动物园(KMP)

本文介绍了一个动物园园长用KMP算法教授动物的故事背景,深入解析了next数组和num数组的概念,以及如何在O(L)的时间复杂度内求解num数组,通过实例说明了算法的具体应用。

题面

【题目描述】
近日,园长发现动物园中好吃难做的动物越来越多了。例如企鹅,只会卖萌向游客要吃的。为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决定开设算法班,让动物们学习算法。
某天,园长给动物们讲解KMPKMPKMP算法。
园长:“对于一个字符串SSS,它的长度为LLL。我们可以在O(L)O(L)O(L)的时间内,求出一个名为nextnextnext的数组。有谁预习了nextnextnext数组的含义吗?”
熊猫:“对于字符串SSS的前iii个字符构成的子串,既是它的后缀又是它的前缀的字符串中(它本身除外),最长的长度记作next[i]next[i]next[i]。”
园长:“非常好!那你能举个例子吗?”
熊猫:“例SSSabcababcabcababcabcababc,则next[5]=2next[5]=2next[5]=2。因为SSS的前555个字符为abcababcababcabababab既是它的后缀又是它的前缀,并且找不到一个更长的字符串满足这个性质。同理,还可得出next[1]=next[2]=next[3]=0,next[4]=next[6]=1,next[7]=2,next[8]=3。”ext[1] = next[2] = next[3] = 0,next[4] = next[6] = 1,next[7] = 2,next[8] = 3。”ext[1]

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值