LeetCode热题100-有效的括号

给定一个只包括 '('')''{''}''['']' 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。
  3. 每个右括号都有一个对应的相同类型的左括号。

因为需要判断左右括号的顺序,所以需要引入栈结构保证左右顺序是正确的,如果不正确直接判定为无效。

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

        stack = []

        for char in s:
            if char in match_tmp:
                if not stack or stack.pop() != match_tmp[char]:
                    return False
            else:
                stack.append(char)
        
        return len(stack) == 0
相关推荐
零号全栈寒江独钓4 小时前
基于c/c++实现linux/windows跨平台获取ntp网络时间戳
linux·c语言·c++·windows
左手厨刀右手茼蒿4 小时前
Linux 内核中的进程管理:从创建到终止
linux·嵌入式·系统内核
geinvse_seg4 小时前
中小团队如何低成本搭建项目管理系统?基于 Ubuntu 的 Dootask 私有化部署实战
linux·运维·ubuntu
CSCN新手听安4 小时前
【linux】高级IO,以ET模式运行的epoll版本的TCP服务器实现reactor反应堆
linux·运维·服务器·c++·高级io·epoll·reactor反应堆
丶伯爵式4 小时前
Ubuntu 24.04 更换国内软件源指南 | 2026年3月26日
linux·运维·ubuntu·国内源·升级
左手厨刀右手茼蒿4 小时前
Linux 内核中的 DMA 管理:从缓冲区到传输
linux·嵌入式·系统内核
被开发耽误的大厨4 小时前
1、==、equals、hashCode底层原理?重写场景?
算法·哈希算法
Java后端的Ai之路4 小时前
Linux端口进程查找与终止教程
linux·运维·服务器
WolfGang0073215 小时前
代码随想录算法训练营 Day38 | 动态规划 part11
算法·动态规划