LeetCode讲解篇之2466. 统计构造好字符串的方案数

文章目录

题目描述

题解思路

组成长度为i的字符串个数 = 组成长度为i - zero的字符串个数 + 组成长度为i - one的字符串个数

设数组f中i号元素的值为组成长度为i的字符串个数

则状态转移方程为f[i] = f[i - zero] + f[i - one],其中需要舍弃为负数的下标

最终我们计算完f中所有值后,计算f数组中[low, high]区间和就为此题的答案

我们需要注意在进行计算过程中要对1000000007取余

题解代码

go 复制代码
func countGoodStrings(low int, high int, zero int, one int) int {
    f := make([]int, high + 1)
    f[0] = 1
    for i := 1; i <= high; i++ {
        if i >= zero {
            f[i] = f[i - zero]
        }
        if i >= one {
            f[i] += f[i - one]
        }

        f[i] = f[i] % 1000000007
    }

    ans := 0
    for i := low; i <= high; i++ {
        ans += f[i]
    }

    return ans % 1000000007
}

题目链接

https://leetcode.cn/problems/count-ways-to-build-good-strings/

相关推荐
wen__xvn2 分钟前
基础数据结构第08天:栈(实战篇)
数据结构·c++·算法
玄鱼殇3 分钟前
前端排序算法
算法·排序算法
tqs_1234511 分钟前
倒排索引数据结构
java·前端·算法
a程序小傲14 分钟前
听说前端又死了?
开发语言·前端·mysql·算法·postgresql·深度优先
副露のmagic15 分钟前
python基础复健
python·算法
bclshuai18 分钟前
深度学习算法辅助股票分析
人工智能·深度学习·算法
mit6.82420 分钟前
437贪心
算法
hetao173383720 分钟前
2026-01-19~20 hetao1733837 的刷题笔记
c++·笔记·算法
秋刀鱼程序编程41 分钟前
Java编程基础入门(四)---选择循环语句
java·开发语言·算法
wen__xvn44 分钟前
基础算法集训第04天:选择排序和冒泡排序
数据结构·算法·leetcode