近日,园长发现动物园中好吃懒做的动物越来越多了。例如企鹅,只会卖萌向游客要吃的。为了整治动物园的不良风气,让动物们凭自己的真才实学向游客要吃的,园长决定开设算法班,让动物们学习算法。
下课前,园长提出了一个问题: KMP 算法只能求出 数组。我现在希望求出一个更强大 数组——对于字符串 的前 个字符构成的子串,既是它的后缀同时又是它的前缀,并且该后缀与该前缀不重叠,将这种字符串的数量记作 。
最后,园长给出了奖励条件,第一个做对的同学奖励巧克力一盒。听了这句话,睡了一节课的企鹅立刻就醒过来了!但企鹅并不会做这道题,于是向参观动物园的你寻求帮助。你能否帮助企鹅写一个程序求出 数组呢?
Constraints
,
Solution
即是后缀又是前缀的性质与 KMP 算法的 fail 数组很接近,在处理时顺便记录答案即可。
Code
1 |
|