获取周期串的最小长度
如果一个字符串可以由某个长度为K的字符串重复多次得到,我们说该串以K为周期。给定一个串,输出它的最小周期。
(function (){ arr="adacdefadacdefadacdefadacdefadacdefadacdef"; var len =arr.length; for(var i=1;i<=len;i++) if(len % i == 0){ //i即为周期,从1开始。并必能整除给定字串长度 var ok=1; for(var j=i;j<len;j++){ //假定前i个字符为周期串,从i+1开始进行检测 if(arr[j]!=arr[j%i]){ //注意 j 和 j%i 的关系,正好是两个指针以i为周期向后扫描。 ok=0; break; } } if(ok>0){ console.log(i); break; } } })();