力扣20.有效的括号、155.最小栈

20.有效的括号

思路:

重在列举出每一种情况:1. 遇到左括号就将右括号进栈;2. 遇到右括号先判断栈是否为空,为空就说明没有对应的左括号,然后判断栈顶元素是否与当前左括号相等,若不等,则说明无法与对应位置的左括号配对;3. 判断玩前两种情况后,剩下的就是合理的右括号,出栈对应元素。

最后还需要判断栈是否为空,必须要为空左右括号的数量才能对应,返回True,否则返回False。

代码:

python 复制代码
class Solution:
    def isValid(self, s: str) -> bool:
        stack = []

        for i in s:
            if i == '(':
                stack.append(')')
            elif i == '[':
                stack.append(']')
            elif i == '{':
                stack.append('}')
            elif not stack or stack[-1] != i:  # 栈为空或者栈最后的元素与数组不对应
                return False
            else:
                stack.pop()

        return True if not stack else False  # 还要再判断为空,以免忽略只有左括号的情况

155.最小栈

思路:

用一个辅助的最小栈来记录最小值,注意通用栈入栈、出栈时对最小栈也要进行判断,具体看代码。

代码:

python 复制代码
class MinStack:

    def __init__(self):
        self.stack = []
        self.min_stack = []  # 辅助栈,用来记录自栈底到栈顶递减的数

    def push(self, val: int) -> None:
        self.stack.append(val)
        if not self.min_stack or val <= self.min_stack[-1]:  # 额外用栈记录最小值
            self.min_stack.append(val)

    def pop(self) -> None:
        if self.stack.pop() == self.min_stack[-1]:  # 除了通用栈出栈外还要和最小栈比较 
            self.min_stack.pop()

    def top(self) -> int:
        return self.stack[-1]

    def getMin(self) -> int:
        return self.min_stack[-1]
相关推荐
汀、人工智能15 小时前
[特殊字符] 第21课:最长有效括号
数据结构·算法·数据库架构·图论·bfs·最长有效括号
花酒锄作田15 小时前
Postgres - Listen/Notify构建轻量级发布订阅系统
python·postgresql
Boop_wu16 小时前
[Java 算法] 字符串
linux·运维·服务器·数据结构·算法·leetcode
Thomas.Sir16 小时前
第二章:LlamaIndex 的基本概念
人工智能·python·ai·llama·llamaindex
故事和你9116 小时前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
m0_6948455716 小时前
Dify部署教程:从AI原型到生产系统的一站式方案
服务器·人工智能·python·数据分析·开源
Fcy64816 小时前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
kvo7f2JTy17 小时前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
List<String> error_P17 小时前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
李昊哲小课18 小时前
Python办公自动化教程 - 第7章 综合实战案例 - 企业销售管理系统
开发语言·python·数据分析·excel·数据可视化·openpyxl