3258. 统计满足 K 约束的子字符串数量 I

高效计算满足 K 约束的子字符串数量:两种解法解析

在字符串处理问题中,如何高效地计算满足特定条件的子字符串个数是一个常见的挑战。在本篇博客中,我们将探讨一个典型的字符串问题:给定一个二进制字符串 s 和一个整数 k,要求我们计算所有满足如下条件的子字符串数量:

  • 子字符串中 0 的数量不超过 k,或者
  • 子字符串中 1 的数量不超过 k

我们将展示两种不同的解法:一种是暴力解法,另一种是使用 滑动窗口 技术的优化解法。

问题分析

假设我们给定了一个二进制字符串 s 和整数 k,我们的目标是计算字符串中所有满足以下条件的子字符串数量:

  • 子字符串中 0 的数量最多为 k
  • 子字符串中 1 的数量最多为 k

例如:

示例 1:

输入: s = "10101", k = 1
输出: 12

示例 2:

输入: s = "1010101", k = 2
输出: 25

方案 1:暴力解法

暴力解法的思路很简单:枚举字符串中的所有子字符串,并检查每个子字符串中 01 的数量是否满足条件。如果满足条件,就计数。

代码实现:
class Solution:
    def countKConstraintSubstrings(self, s: str, k: int) -> int:
        n = len(s)
        ans = 0
        for i in range(n):
            cnt0 = 0
            cnt1 = 0
       
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值