Leetcode 20. 有效的括号

心路历程:

看到括号问题直接想到栈,但是纠结了一下题目中给出的 '2. 左括号必须以正确的顺序闭合' 这一约束,其实这句话的意思简化了题目要求,'[(])'这样的字符串就不满足要求了。

注意的点:

1、注意最后需要栈为空的时候才能返回true,否则代表左括号可能会多余。

解法:栈

python 复制代码
class Solution:
    def isValid(self, s: str) -> bool:
        # 栈
        from collections import deque
        stack = deque([])
        lefts, rights = ['(', '[', '{'], [')', ']', '}']
        mappings_right = {')':'(', ']':'[', '}':'{'}
        for c in s:
            if c in lefts:
                stack.append(c)
            else:
                if len(stack) == 0: return False
                if stack.pop() != mappings_right[c]: return False
        if len(stack) == 0: return True
        else: return False
相关推荐
01二进制代码漫游日记2 分钟前
自定义类型:联合和枚举(一)
c语言·开发语言·学习·算法
小学卷王25 分钟前
复试day25
算法
样例过了就是过了34 分钟前
LeetCode热题100 和为 K 的子数组
数据结构·算法·leetcode
二年级程序员34 分钟前
单链表算法思路详解(下)
c语言·数据结构·算法
HAPPY酷1 小时前
C++ 成员指针(Pointer to Member)完全指南
java·c++·算法
Sunsets_Red1 小时前
浅谈随机化与模拟退火
java·c语言·c++·python·算法·c#·信息学竞赛
Felven1 小时前
A. Add and Divide
数据结构·算法
Frostnova丶1 小时前
LeetCode 67. 二进制求和
算法·leetcode
上海锟联科技1 小时前
DAS 与 FBG 振动监测对比:工程应用中该如何选择?
数据结构·算法·分布式光纤传感
星火开发设计1 小时前
模板参数:类型参数与非类型参数的区别
java·开发语言·前端·数据库·c++·算法