博客
关于我
蓝桥杯 周期子串 C++算法提高 HERODING的蓝桥杯之路
阅读量:155 次
发布时间:2019-02-28

本文共 959 字,大约阅读时间需要 3 分钟。

为了找出给定字符串的最小周期,我们可以使用暴力解法。通过遍历所有可能的周期长度,我们检查每个长度是否满足条件,从而确定最小的周期长度。

方法思路

  • 问题分析:我们需要找出字符串的最小周期,即字符串可以被分解为一个或多个相同子串连接而成的最小长度。
  • 暴力解法:遍历从1到字符串长度的所有可能周期长度k。对于每个k,检查字符串是否由k长度的重复子串构成。
  • 检查条件:对于每个k,首先检查字符串长度是否能被k整除。如果可以,检查每个字符是否与其在基准子串中的位置相同。
  • 优化:一旦找到满足条件的最小k,直接返回结果,避免不必要的计算。
  • 解决代码

    #include 
    using namespace std;int main() { char s[100]; int n = strlen(s); for (int k = 1; k <= n; ++k) { if (n % k != 0) { continue; } bool valid = true; for (int i = 0; i < n; ++i) { if (s[i] != s[i % k]) { valid = false; break; } } if (valid) { cout << k << endl; return 0; } } // 根据题目,所有情况都能找到周期,因此无需处理 return n;}

    代码解释

  • 读取输入:字符串 s 被读取,长度为 n
  • 遍历可能的周期长度:从1到 n 遍历每个可能的周期长度 k
  • 检查整除性:如果 n 不能被 k 整除,跳过当前 k
  • 验证周期性:检查字符串是否由 k 长度的重复子串构成。取前 k 个字符作为基准,逐个字符检查后续字符是否与基准字符相同。
  • 输出结果:找到最小的满足条件的 k,输出并结束程序。
  • 这种方法确保了我们能准确找到字符串的最小周期,并且在合理的时间内完成计算。

    转载地址:http://ockj.baihongyu.com/

    你可能感兴趣的文章
    NetBeans IDE8.0需要JDK1.7及以上版本
    查看>>
    netcat的端口转发功能的实现
    查看>>
    netfilter应用场景
    查看>>
    netlink2.6.32内核实现源码
    查看>>
    Netpas:不一样的SD-WAN+ 保障网络通讯品质
    查看>>
    NetScaler的常用配置
    查看>>
    netsh advfirewall
    查看>>
    NETSH WINSOCK RESET这条命令的含义和作用?
    查看>>
    Netty WebSocket客户端
    查看>>
    netty 主要组件+黏包半包+rpc框架+源码透析
    查看>>
    Netty 异步任务调度与异步线程池
    查看>>
    Netty中集成Protobuf实现Java对象数据传递
    查看>>
    Netty事件注册机制深入解析
    查看>>
    Netty原理分析及实战(四)-客户端与服务端双向通信
    查看>>
    Netty客户端断线重连实现及问题思考
    查看>>
    Netty工作笔记0006---NIO的Buffer说明
    查看>>
    Netty工作笔记0007---NIO的三大核心组件关系
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0013---Channel应用案例4Copy图片
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>