Leetcode刷题Python之3258.统计满足k约束的子字符串I

news2024/11/24 14:02:00

提示:暴力解法简单易懂能通过。

文章目录

  • 一、题目描述
    • 示例分析
  • 二、解题思路
  • 三、代码实现
    • 代码解析
  • 总结


一、题目描述

给定一个二进制字符串 s(即字符串中只包含字符 0 和 1)以及一个整数 k。要求计算出 s 中满足 “k 约束” 的子字符串数量。满足 k 约束的子字符串定义如下:
1.子字符串中 0 的数量最多为 k。
2.子字符串中 1 的数量最多为 k。

只要子字符串满足以上任意一个条件,即可认为其符合 k 约束条件。


示例分析

示例一

输入:s = "10101", k = 1
输出:12
解释:字符串中,除了 "1010"、"10101" 和 "0101" 以外的其他子字符串都满足 k 约束。

示例二

输入:s = "1010101", k = 2
输出:25
解释:字符串中,长度超过 5 的子字符串不满足 k 约束,其余子字符串均满足。

示例三

输入:s = "11111", k = 1
输出:15
解释:所有子字符串都满足 k 约束。

二、解题思路

为了满足题目要求,我们可以采用暴力法。暴力法的核心思路是枚举 s 中的所有可能子字符串,然后逐个检查每个子字符串的 0 和 1 的数量,判断其是否符合 k 约束条件。这种方法尽管时间复杂度较高,但逻辑简单清晰,适合约束条件低的题目。

具体步骤如下:

1.双重循环生成子字符串:遍历每一个可能的子字符串,并逐个计算每个子字符串中的 0 和 1 数量。

2.计数更新:对于每个生成的子字符串,检查 0 和 1 的数量。如果满足 0 的数量不超过 k 或 1 的数量不超过 k,则增加计数。

3.提前终止内层循环:一旦发现某个子字符串同时不满足 0 和 1 的数量限制,直接跳出内层循环,这样可以节省部分计算量。

三、代码实现

代码如下:

class Solution(object):
    def countKConstraintSubstrings(self, s, k):
        """
        :type s: str
        :type k: int
        :rtype: int
        """
        n = len(s)
        count = 0  # 用于记录满足条件的子字符串数量

        # 遍历每一个子字符串的起始位置
        for i in range(n):
            zero_count = 0  # 当前子字符串中 0 的数量
            one_count = 0   # 当前子字符串中 1 的数量

            # 遍历从 i 开始的每一个可能的结束位置 j
            for j in range(i, n):
                # 更新 01 的数量
                if s[j] == '0':
                    zero_count += 1
                else:
                    one_count += 1

                # 检查是否满足任意一个 k 约束条件
                if zero_count <= k or one_count <= k:
                    count += 1  # 满足条件,计数加一
                else:
                    # 一旦两个条件都不满足,跳出当前循环
                    break

        return count

代码解析

1.变量定义
n 表示字符串的长度。
count 用于记录所有满足条件的子字符串数量。
zero_count 和 one_count 分别记录当前子字符串中 0 和 1 的数量。

2.双层循环
外层循环的变量 i 表示子字符串的起始位置。
内层循环的变量 j 表示子字符串的结束位置,从起始位置 i 开始遍历到字符串末尾。
在遍历过程中,根据字符是 0 还是 1,更新 zero_count 或 one_count。

3.条件判断
每次计算子字符串的 0 和 1 数量后,如果满足 zero_count <= k 或 one_count <= k,将计数 count 加一。
如果 zero_count 和 one_count 均超过 k,直接跳出内层循环,因为在当前起点 i 的条件下,不可能找到更多满足 k 约束的子字符串。


总结

时间复杂度:本算法的时间复杂度为 O(n^2),其中 n 是字符串的长度。因为对于每一个起始位置 i,我们要检查以 i 为起点的所有可能子字符串。
空间复杂度:O(1),只需要一些常量空间来记录 0 和 1 的数量,以及符合条件的子字符串数量。

虽然暴力法的时间复杂度较高,但对于中小规模的输入,性能可以接受。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2239261.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

链游系统定制化开发:引领游戏产业的新时代

在数字革命的浪潮中&#xff0c;链游&#xff08;区块链游戏&#xff09;作为一种新兴游戏形式&#xff0c;正重新定义游戏产业的发展方向。链游将区块链技术与传统游戏结合&#xff0c;使游戏体验更加公平透明&#xff0c;并赋予玩家真正的资产所有权。这一领域不仅为玩家带来…

【AI换装整合包及教程】CatVTON与其他虚拟试衣技术的详细对比

一、概述 虚拟试衣技术近年来发展迅猛&#xff0c;尤其在电商领域的应用备受瞩目。CatVTON作为一种新兴的虚拟试衣技术&#xff0c;凭借其轻量化设计和高效训练策略脱颖而出。本文将从网络结构、训练策略、推理过程及应用场景四个方面详细对比CatVTON与其他主流虚拟试衣技术。…

元宇宙及其技术

“元宇宙”&#xff08;Metaverse&#xff09;是一个结合了现实与虚拟的数字世界的概念。这个词最早由作家尼尔斯蒂芬森&#xff08;Neal Stephenson&#xff09;在其1992年的科幻小说《雪崩》&#xff08;Snow Crash&#xff09;中提出。元宇宙通常被描述为一个共享的虚拟空间…

三种单例实现

1、不继承Mono的单例 实现 使用 注&#xff1a; 使用需要继承BaseManager 泛型填写自己本身 需要实现无参构造函数 2、挂载式的Mono单例 实现 使用 注&#xff1a; 使用需要继承SingletonMono 泛型填写自己本身 需要挂载在unity引擎面板 3、不用挂载式的单例 实现 使…

移动取证和 Android 安全

当今的数字时代已经产生了许多技术进步&#xff0c;无论是智能手机还是虚拟现实、人工智能和物联网 (IoT) 等下一代基础技术。 智能手机已不再只是奢侈品&#xff0c;而是我们生存所必需的东西。根据各种统计数据&#xff0c;如今全球有超过 50% 的人使用手机。 由于数据存储…

视频孪生技术在金融银行网点场景中的应用价值

作为国民经济重要的基础行业&#xff0c;金融行业在高速发展的同时衍生出业务纠纷、安全防范、职能管理等诸多问题&#xff0c;对安全防范和监督管理提出了更高的要求。因此&#xff0c;如何能更好的利用视频监控系统价值&#xff0c;让管理人员更简便的浏览监控视频、更快速的…

Prompt Engineering 提示工程

一、什么是提示工程&#xff08;Prompt Engineering&#xff09; Prompt 就是发给大模型的指令&#xff0c;比如讲个笑话、用 Python 编个贪吃蛇游戏等&#xff1b;大模型只接受一种输入&#xff0c;那就是 prompt。本质上&#xff0c;所有大模型相关的工程工作&#xff0c;都是…

【大语言模型】ACL2024论文-09 无监督信息精细化训练用于增强大型语言模型的检索增强生成

【大语言模型】ACL2024论文-09 无监督信息精细化训练用于增强大型语言模型的检索增强生成 目录 文章目录 【大语言模型】ACL2024论文-09 无监督信息精细化训练用于增强大型语言模型的检索增强生成目录1. 论文信息2. 摘要3. 研究背景4. 问题与挑战5. 如何解决6. 创新点7. 算法模…

【服务器】使用命令行文本编辑器(如 vim、nano 或 vi)创建文件并编辑

【服务器】使用命令行文本编辑器&#xff08;如 vim、nano 或 vi&#xff09;创建文件并编辑 准备&#xff1a;连接至服务器&#xff08;如ssh&#xff09;创建 .ncl 文件方法 1: 使用 vim 创建 .ncl 文件方法 2: 使用 nano 创建 .ncl 文件确认文件已创建运行 .ncl 文件 总结参…

AI大模型如何赋能电商行业,引领变革?

AI大模型赋能电商行业 引领变革之路 随着技术的发展&#xff0c;人工智能&#xff08;AI&#xff09;在电商行业中的应用越来越广泛。通过利用AI大模型&#xff0c;电商平台能够显著提高销售效率&#xff0c;优化用户体验&#xff0c;提升供应链管理水平&#xff0c;从而引领行…

Appium配置2024.11.12

百度得知&#xff1a;谷歌从安卓9之后不再提供真机layout inspector查看&#xff0c;仅用于支持ide编写的app调试用 所以最新版android studio的android sdk目录下已经没有了布局查看工具... windows x64操作系统 小米k30 pro手机 安卓手机 Android 12 第一步&#xff1a…

ollama+springboot ai+vue+elementUI整合

1. 下载安装ollama (1) 官网下载地址&#xff1a;https://github.com/ollama/ollama 这里以window版本为主&#xff0c;下载链接为&#xff1a;https://ollama.com/download/OllamaSetup.exe。 安装完毕后&#xff0c;桌面小图标有一个小图标&#xff0c;表示已安装成功&…

【Linux】-学习笔记03

第十一章-管理Linux软件包和进程 1.源码下载安装软件 1.1概念 源码文件&#xff1a;程序编写者使用C或C等语言编写的原始代码文本文件 源码文件使用.tar.gz或.tar.bz2打包成压缩文件 1.2特点 源码包可移植性好&#xff0c;与待安装软件的工作环境依赖性不大 由于有编译过程…

从手动到自动:掌握Shell脚本转换为System服务的魔法!

背景介绍 从 Ubuntu 17.10 版本开始&#xff0c;系统默认不再包含 /etc/rc.local 文件了&#xff0c;这是因为systemd已经成为了主要的系统初始化工具。不过别担心&#xff0c;如果你希望在开机时自动运行一些特定的命令&#xff0c;可以通过创建一个简单的 Shell脚本&#xf…

力扣-Hot100-哈希【算法学习day.30】

前言 ###我做这类文档一个重要的目的还是给正在学习的大家提供方向&#xff08;例如想要掌握基础用法&#xff0c;该刷哪些题&#xff1f;&#xff09;我的解析也不会做的非常详细&#xff0c;只会提供思路和一些关键点&#xff0c;力扣上的大佬们的题解质量是非常非常高滴&am…

【数字静态时序分析】复杂时钟树的时序约束SDC写法

以上图为例&#xff0c;SoC芯片上往往存在几种不同的时钟源&#xff0c;有pll时钟、环振时钟、外部的晶振时钟&#xff0c;在SoC不同的模块或者不同的运行阶段使用的时钟也往往不同&#xff0c;所以在使用的时候&#xff0c;相同的模块会出现选择不同的时钟源的情况。上图的情形…

前端Cypress自动化测试全网详解

Cypress 自动化测试详解&#xff1a;从安装到实战 Cypress 是一个强大的端到端&#xff08;End-to-End, E2E&#xff09;功能测试框架&#xff0c;基于 Node.js 构建&#xff0c;支持本地浏览器直接模拟测试&#xff0c;并具有测试录屏功能&#xff0c;极大地方便了测试失败时的…

Qt_day4_Qt_UI设计

目录 Qt_UI设计 1. Designer 设计师&#xff08;掌握&#xff09; 2. Layout 布局&#xff08;重点&#xff09; 2.1 基本使用 2.2 高级用法 2.3 代码布局&#xff08;了解&#xff09; 3. Designer与C的关系&#xff08;熟悉&#xff09; 4. 基本组件&#xff08;掌握…

杨中科 .Net Core 笔记 DI 依赖注入2

ServiceCollection services new ServiceCollection();//定义一个承放服务的集合 services.AddScoped<iGetRole, GetRole>();using (ServiceProvider serviceProvider services.BuildServiceProvider()) {var list serviceProvider.GetServices(typeof(iGetRole));//获…

机器学习—Additional Layer Types

到目前为止&#xff0c;我们使用的所有神经网络都是密集型的&#xff0c;一层中的每个神经元&#xff0c;上一层的所有激活&#xff0c;事实证明&#xff0c;仅仅使用密集层类型&#xff0c;可以建立一些非常强大的学习算法&#xff0c;并帮助你建立关于神经网络能做什么的进一…