当前位置: 首页 > article >正文

算法求解 -- (炼码 3854 题)计算满足条件的好二进制字符串数量

文章目录

  • 1. 问题描述(炼码 3854 题)
  • 2. 解决方案概述
  • 3. 动态规划详解
  • 4. 代码实现
  • 5. 示例解析
  • 6. 总结


1. 问题描述(炼码 3854 题)

给定四个正整数 minLength、maxLength、zeroGroup 和 oneGroup。需要找到所有的 好二进制字符串,一个 好二进制字符串 需要满足以下条件:

  • 字符串长度在 [minLength, maxLength] 之间。
  • 对于字符串中的每块连续 0 的子串,其长度必须是 zeroGroup 的整数倍。
  • 对于字符串中的每块连续 1 的子串,其长度必须是 oneGroup 的整数倍。
  • 0 被认为是所有数字的整数倍,即对于 zeroGroup = 2,oneGroup = 3,字符串 “00” 和 “111” 可以被认为是一个好二进制字符串。

返回满足条件的好二进制字符串的数量,答案可能很大,返回对10的9次方+7取余后的结果。

2. 解决方案概述

为了高效地解决这个问题,我们可以使用 动态规划。定义 dp[i] 表示长度为 i 的好二进制字符串的数量。通过状态转移方程,我们可以逐步计算出所有满足条件的字符串数量。

3. 动态规划详解

状态定义

  • dp[i]:表示长度为 i 的好二进制字符串的数量。

状态转移方程

  • 如果在长度为 i 的字符串末尾添加 zeroGroup 个 0,则新字符串的长度为 i + zeroGroup,并且必须满足 i + zeroGroup 在 [minLength, maxLength] 范围内。
  • 如果在长度为 i 的字符串末尾添加 oneGroup 个 1,则新字符串的长度为 i + oneGroup,并且必须满足 i + oneGroup 在 [minLength, maxLength] 范围内。

初始化

  • dp[0] = 1:表示空字符串是一种有效的初始状态。

结果计算

  • 遍历所有在 [minLength, maxLength] 范围内的长度,累加对应的 dp 值。

4. 代码实现

using System;

public class Solution {
    public int CountGoodBinaryStrings(int minLength, int maxLength, int zeroGroup, int oneGroup) {
        const int MOD = 1000000007;
        int[] dp = new int[maxLength + 1];
        dp[0] = 1; // 空字符串是一种有效的初始状态

        for (int i = 0; i <= maxLength; i++) {
            if (i + zeroGroup <= maxLength) {
                dp[i + zeroGroup] = (dp[i + zeroGroup] + dp[i]) % MOD;
            }
            if (i + oneGroup <= maxLength) {
                dp[i + oneGroup] = (dp[i + oneGroup] + dp[i]) % MOD;
            }
        }

        int result = 0;
        for (int i = minLength; i <= maxLength; i++) {
            result = (result + dp[i]) % MOD;
        }

        return result;
    }

    public static void Main(string[] args) {
        Solution solution = new Solution();

        // 示例 1
        int minLength1 = 2, maxLength1 = 3, zeroGroup1 = 2, oneGroup1 = 1;
        int result1 = solution.CountGoodBinaryStrings(minLength1, maxLength1, zeroGroup1, oneGroup1);
        Console.WriteLine($"Example 1: {result1}"); // 输出: 5

        // 示例 2
        int minLength2 = 4, maxLength2 = 4, zeroGroup2 = 3, oneGroup2 = 4;
        int result2 = solution.CountGoodBinaryStrings(minLength2, maxLength2, zeroGroup2, oneGroup2);
        Console.WriteLine($"Example 2: {result2}"); // 输出: 1
    }
}

5. 示例解析

示例 1
输入:minLength = 2, maxLength = 3, zeroGroup = 2, oneGroup = 1
输出:5
解释:满足条件的好二进制字符串有 “00”, “11”, “001”, “100”, “111”。
示例 2
输入:minLength = 4, maxLength = 4, zeroGroup = 3, oneGroup = 4
输出:1
解释:满足条件的好二进制字符串只有 “1111”。

6. 总结

通过动态规划,我们可以高效地计算出满足条件的好二进制字符串的数量。动态规划的核心思想是通过状态转移方程逐步构建解,从而避免重复计算。


http://www.kler.cn/a/393868.html

相关文章:

  • C++ 如何将 gRPC集成到机器人系统中
  • 【C++】C++11(二)
  • Windows 11 上配置VSCode 使用 Git 和 SSH 完整步骤
  • Git最便捷的迁移方式
  • 【电子通识】PWM驱动让有刷直流电机恒流工作
  • 【cuda学习日记】2.2 使用2维网络(grid)和2维块(block)对矩阵进行求和
  • 基于SSM(Spring + Spring MVC + MyBatis)框架开发的电能计量与客服服务管理系统
  • 蓝队基础1
  • curl 安装最新版
  • 在 Spring Boot 中实时监控 Redis 命令流
  • 基于Java高校排课系统
  • Thread类及常见方法
  • 【Qt】在 Qt Creator 中使用图片资源方法(含素材网站推荐)
  • 实现API接口的自动化
  • PostgreSQL 开启密码验证插件
  • Spring-Webflux + Reactor + Netty 初体验
  • LeetCode【0017】电话号码的字母组合
  • Docker 基础命令介绍和常见报错解决
  • scala 迭代更新
  • Spring框架之适配器模式 (Adapter Pattern)
  • 江苏博才众创科技产业园集团拟投资10亿元在泰兴打造汽车零部件产业园
  • c#程序结构
  • 探索 HTTP 请求方法:GET、POST、PUT、DELETE 等的用法详解
  • 低代码、配置式web组态软件
  • Nop平台的定位及发展规划
  • 如何通过AB测试找到最适合的Yandex广告内容