【leetcode——栈的题目】——1003. 检查替换后的词是否有效python

2024-05-30 02:12

本文主要是介绍【leetcode——栈的题目】——1003. 检查替换后的词是否有效python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:

给你一个字符串 s ,请你判断它是否 有效 。

字符串 s 有效 需要满足:假设开始有一个空字符串 t = "" ,你可以执行 任意次 下述操作将 t 转换为 s :

  • 将字符串 "abc" 插入到 t 中的任意位置。形式上,t 变为 tleft + "abc" + tright,其中 t == tleft + tright 。注意,tleft 和 tright 可能为  。

如果字符串 s 有效,则返回 true;否则,返回 false

示例 1:

输入:s = "aabcbc"
输出:true
解释:
"" -> "abc" -> "aabcbc"
因此,"aabcbc" 有效。

示例 2:

输入:s = "abcabcababcc"
输出:true
解释:
"" -> "abc" -> "abcabc" -> "abcabcabc" -> "abcabcababcc"
因此,"abcabcababcc" 有效。

示例 3:

输入:s = "abccba"
输出:false
解释:执行操作无法得到 "abccba" 。

提示:

  • 1 <= s.length <= 2 * (10 ** 4)
  • s 由字母 'a''b' 和 'c' 组成

题解:

一.需要的知识

这道题需要用到一个数据结构,它的名字叫 ,那么什么是栈呢?

数据结构中的栈(Stack)是一种特殊的线性数据结构,它遵循后进先出(LIFO,Last In First Out)的原则。这意味着最后一个被放入栈中的元素将是第一个被取出的元素。栈通常用于处理需要按特定顺序执行的任务,例如函数调用和递归、括号匹配、表达式求值等

还是不懂?     

这会直接懂了吧~

那么在python中怎么操作呢?

        1.创建栈

在Python中,你可以简单地通过创建一个空列表来初始化一个栈。

stack = []

        2.入栈(Push)

使用列表的append()方法可以将元素添加到栈顶。

stack.append('A') # 将元素'A'入栈
stack.append('B') # 将元素'B'入栈

        3.出栈(Pop)

使用列表的pop()方法并指定索引为-1可以移除并返回栈顶的元素。

top_element = stack.pop(-1) # 出栈操作,移除并返回栈顶元素,这里是'B'

如果不传递索引给pop()方法,它默认会弹出列表中的最后一个元素,这正是我们想要的栈行为。

top_element = stack.pop() # 同样是出栈操作,移除并返回栈顶元素

        4.查看栈顶元素(Peek 或 Top)

你可以通过索引-1来查看栈顶元素,但不移除它。

top_element = stack[-1] # 查看栈顶元素,这里是'A'

        5.判断栈是否为空

使用列表的长度来判断栈是否为空。

is_empty = len(stack) == 0 # 如果栈的长度为0,则为空

        6.获取栈的大小

使用len()函数来获取栈中元素的数量。

stack_size = len(stack) # 获取栈的大小

二.题解

class Solution:def isValid(self, s: str) -> bool:#1.字符串存在包含关系#2.数据结构为栈#3.只管a和c如果栈中无a但是遇到了入栈的c那么就是False#4.遇到ab就入栈即可#5.如果遇到c,那就判断栈的顶是不是b和栈顶的前一个是不是astack = []for i in range(len(s)):if s[i] == "c":if len(stack) < 2:return False elif stack.pop(-2) != "a" or stack.pop() != "b":return False else:stack.append(s[i])if len(stack) != 0:return Falsereturn True

题解在这里,如果是刚遇到这种数据结构的小伙伴,建议做一下这道题:20. 有效的括号

做完之后再来看这道题,或许就能了解很多。

结尾:

如果想刷力扣题没有团队没有动力怎么办?大家可以加入我的刷题群,一起刷题,有想进群的可以在底下评论:进群0.0

感谢大家的浏览,如有错误,望指正。

这篇关于【leetcode——栈的题目】——1003. 检查替换后的词是否有效python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

linux批量替换文件内容的实现方式

《linux批量替换文件内容的实现方式》本文总结了Linux中批量替换文件内容的几种方法,包括使用sed替换文件夹内所有文件、单个文件内容及逐行字符串,强调使用反引号和绝对路径,并分享个人经验供参考... 目录一、linux批量替换文件内容 二、替换文件内所有匹配的字符串 三、替换每一行中全部str1为st

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

基于Python实现简易视频剪辑工具

《基于Python实现简易视频剪辑工具》这篇文章主要为大家详细介绍了如何用Python打造一个功能完备的简易视频剪辑工具,包括视频文件导入与格式转换,基础剪辑操作,音频处理等功能,感兴趣的小伙伴可以了... 目录一、技术选型与环境搭建二、核心功能模块实现1. 视频基础操作2. 音频处理3. 特效与转场三、高

Python实现中文文本处理与分析程序的示例详解

《Python实现中文文本处理与分析程序的示例详解》在当今信息爆炸的时代,文本数据的处理与分析成为了数据科学领域的重要课题,本文将使用Python开发一款基于Python的中文文本处理与分析程序,希望... 目录一、程序概述二、主要功能解析2.1 文件操作2.2 基础分析2.3 高级分析2.4 可视化2.5

一文解密Python进行监控进程的黑科技

《一文解密Python进行监控进程的黑科技》在计算机系统管理和应用性能优化中,监控进程的CPU、内存和IO使用率是非常重要的任务,下面我们就来讲讲如何Python写一个简单使用的监控进程的工具吧... 目录准备工作监控CPU使用率监控内存使用率监控IO使用率小工具代码整合在计算机系统管理和应用性能优化中,监

Python实现终端清屏的几种方式详解

《Python实现终端清屏的几种方式详解》在使用Python进行终端交互式编程时,我们经常需要清空当前终端屏幕的内容,本文为大家整理了几种常见的实现方法,有需要的小伙伴可以参考下... 目录方法一:使用 `os` 模块调用系统命令方法二:使用 `subprocess` 模块执行命令方法三:打印多个换行符模拟

Python实现MQTT通信的示例代码

《Python实现MQTT通信的示例代码》本文主要介绍了Python实现MQTT通信的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 安装paho-mqtt库‌2. 搭建MQTT代理服务器(Broker)‌‌3. pytho

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习