POJ 2406 Power Strings

KMP算法循环节证明
本文详细解析了一道关于KMP算法中循环节的问题,通过具体实例解释如何判断一个字符串是否由若干个相同子串重复构成,并给出了清晰的数学证明。

我这里要说的是一点证明,这题的题意和思路转自依然:

题意:给出一个串,问你这个最多是多少个相同的字串重复连接而成的。如:ababab则最多有3个ab连接而成。

 

思路:KMP中的get_next(),或者get_nextval(),对next数组的应用。next[len]是最后一个字符跳的步长,如果他有相同字符串,则该串长度是len-next[len](这点我还在想要怎么证明!)...如果整个长度len能分解成x个这种串(能整除),就得到ans了。否则不能分解。只能是由他自己组成串,长度为1。

   


 以前做过的题,现在准备学自动机,又看了看KMP,发现这里我对这里的循环节的证明不是很能想得明白,于是自己在草稿本上证了下,其实挺简单的,我在这里帮大家证明下。

证明:

现在把给定的字符串分成n段(n也就是上面提到的len/(len - next[len])),然后位移后可以明显得出n-1段等于n段, n-2段等于n-1段......第一段等于第二段。该字符串本身特点有第n段等于第n段......第一段等于第一段。然后稍微2者联系下,就得到所有的段落全部相同。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值