获取周期串的最小长度

如果一个字符串可以由某个长度为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;
            }
        }
})();
复制代码

 

posted @   zhoutk  阅读(324)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示