博客
关于我
牛客网WY-29 暗黑子字符串
阅读量:302 次
发布时间:2019-03-01

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

为了计算长度为n的字符串中不存在任何长度为3的连续子串包含A、B、C各一个的字符串数目,我们可以使用动态规划的方法。以下是详细的解题思路:

  • 定义状态

    • dp[i] 表示长度为i的字符串中是暗黑字符串的数量。
  • 递推关系

    • 当i >= 3时,dp[i] = 2 * dp[i-1] + dp[i-2]。这是因为每个长度为i的字符串可以由长度为i-1的字符串的两倍加上长度为i-2的字符串构成。
  • 初始化

    • dp[1] = 3:长度为1的字符串有3种可能(A, B, C),都是暗黑的。
    • dp[2] = 9:长度为2的字符串有9种可能,同样都是暗黑的。
  • 计算

    • 计算从dp[3]dp[n]的值,使用上述递推公式。
  • 输出

    • 输入n后,输出对应的dp[n]值。
  • 通过这种方法,我们可以高效地计算出任意长度n的暗黑字符串数目,时间复杂度为O(n),空间复杂度为O(n)。

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

    你可能感兴趣的文章
    mysql_real_connect 参数注意
    查看>>
    mysql_secure_installation初始化数据库报Access denied
    查看>>
    MySQL_西安11月销售昨日未上架的产品_20161212
    查看>>
    Mysql——深入浅出InnoDB底层原理
    查看>>
    MySQL“被动”性能优化汇总
    查看>>
    MySQL、HBase 和 Elasticsearch:特点与区别详解
    查看>>
    MySQL、Redis高频面试题汇总
    查看>>
    MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
    查看>>
    mysql一个字段为空时使用另一个字段排序
    查看>>
    MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
    查看>>
    MYSQL一直显示正在启动
    查看>>
    MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
    查看>>
    MySQL万字总结!超详细!
    查看>>
    Mysql下载以及安装(新手入门,超详细)
    查看>>
    MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
    查看>>
    MySQL不同字符集及排序规则详解:业务场景下的最佳选
    查看>>
    Mysql不同官方版本对比
    查看>>
    MySQL与Informix数据库中的同义表创建:深入解析与比较
    查看>>
    mysql与mem_细说 MySQL 之 MEM_ROOT
    查看>>
    MySQL与Oracle的数据迁移注意事项,另附转换工具链接
    查看>>