首页 > 其他分享 >20.有效的括号

20.有效的括号

时间:2023-11-13 16:24:17浏览次数:25  
标签:返回 return 有效 res 栈顶 20 括号 False

目录

题目

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

    有效字符串需满足:

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

示例 1:

输入:s = "()"
输出:true

示例 2:

输入:s = "()[]{}"
输出:true

示例 3:

输入:s = "(]"
输出:false

法一:栈

  • 思路:遇到左括号就入栈,遇到右括号先判断栈里还有元素没,如果没了直接返回False,其次判断栈顶元素是否匹配,不匹配直接返回false,如果匹配就出栈。遍历完整个字符串后检查栈是否为空,不为空返回False
class Solution:
    def isValid(self, s: str) -> bool:
        res = []  # 用于存储左括号的栈
        i = 0  # 用于遍历字符串的索引
        while i < len(s):
            if s[i] == '(' or s[i] == '[' or s[i] == '{':
                res.append(s[i])  # 遇到左括号,将其加入栈中
            elif s[i] == ')':
                if len(res) == 0 or res[-1] != '(':  # 遇到右括号')',判断栈顶元素是否为对应的左括号'(',如果不是则返回False
                    return False
                res.pop()  # 栈顶元素为对应的左括号'(',出栈
            elif s[i] == ']':
                if len(res) == 0 or res[-1] != '[':  # 遇到右括号']',判断栈顶元素是否为对应的左括号'[',如果不是则返回False
                    return False
                res.pop()  # 栈顶元素为对应的左括号'[', 出栈
            elif s[i] == '}':
                if len(res) == 0 or res[-1] != '{':  # 遇到右括号'}',判断栈顶元素是否为对应的左括号'{',如果不是则返回False
                    return False
                res.pop()  # 栈顶元素为对应的左括号'{', 出栈
            else:
                return False  # 如果遇到非括号字符,直接返回False
            i += 1  # 继续遍历字符串的下一个字符
        if len(res)!=0:
            return False
        return True # 遍历完字符串后,检查栈是否为空,如果栈为空,说明所有括号都匹配,返回True;否则返回False

法二:字典

class Solution:
    def isValid(self, s: str) -> bool:
        dic = {')': '(', ']': '[', '}': '{'}# 使用字典存储右括号与对应的左括号的映射关系
        stack = []# 使用栈来存储左括号
        for char in s:# 遍历字符串中的每个字符
            if char in dic.values():# 如果当前字符是左括号,直接入栈
                stack.append(char)
            elif char in dic: # 如果当前字符是右括号
                if not stack or stack[-1] != dic[char]:# 如果栈为空或栈顶元素与当前字符不匹配,则返回 False
                    return False
                else: # 匹配成功,将栈顶元素出栈
                    stack.pop()
            else: # 如果不是括号字符
                return False
        return not stack  # 最后,如果栈为空,表示所有括号都匹配,返回 True;否则,返回 False

标签:返回,return,有效,res,栈顶,20,括号,False
From: https://www.cnblogs.com/lushuang55/p/17829414.html

相关文章

  • Toyota Programming Contest 2023#7(AtCoder Beginner Contest 328)
    ToyotaProgrammingContest2023#7(AtCoderBeginnerContest328)A.NotTooHard题意:将给定的数列\(a\)中数值小于\(x\)的数累加。解题思路:模拟。代码:#include<bits/stdc++.h>usingnamespacestd;usingll=longlong;voidsolve(){ intn,x; cin>>n>>x;......
  • 每日总结2023年11月13日
    今天在运行vue项目的时候出现了5:9errorComponentname"Index"shouldalwaysbemulti-wordvue/multi-word-component-names的错误,有类似错误的小伙伴可以打开vue.config.js文件在其中添加lintOnSave:false代码,亲测有效。const{defineConfig}=require('@vue/cli-serv......
  • 2023.10.21 CSP-S 复赛游记
    2023.10.21CSP-S复赛游记咕了一段时间。Day-2上午下午正常打模拟赛、改题,晚上开始复习板子。主要是确实忘了很多东西。Day-1上午的模拟赛没参加,打了一天板子。图论还是我的一大弱点。被Tarjan薄纱下午写了个计划,把已经复习的和没有复习的都写出来了,发现要复习的板子......
  • 从嘉手札<2023-11-13>
    1、很多时候成功并不等同于成长成功是很多因素复合形成的一种结果而并不等同于一个人阅历的丰富、认知的提高2、我一直认为世界不属于投机者也不属于堕落者信念感在这个大数据泛滥、碎片化汹涌的年代是我们所欠缺的一种内心的力量或许世界不那么温柔冰冷、孤寂、痛......
  • Premiere Pro 2024专业影像,尽在指尖 mac/win版
    PremierePro2024是一款专业的视频编辑软件,它为影视制作提供了全面的解决方案,从剪辑、调色、音频处理到字幕添加,无所不能。软件界面简洁直观,操作便捷,能够让用户快速上手,并且提供多种创意工具,让用户自由发挥创造力,实现个性化的视频编辑需求。→→↓↓载PremierePro2023mac/win......
  • NOIP2023游记
    Day-417号我们就要出发。好快啊。写了博客,并不是很全,打算回来继续完善。想起之前有个dfs序求lca的坑还没填完。呃等我以后直接重构吧。看了辰星凌的DP优化,打算板刷一下题。UVA的题在\(4\)发UKE后终于AC。给老师批了卷子。NOIP很快就到了,我要告诉自己,爆零就......
  • Readonly只针对input(text/password)和textarea有效,而disabled对于所有的表单元素有效
    Readonly只针对input(text/password)和textarea有效,而disabled对于所有的表单元素有效,包括select,radio,checkbox,button等Readonly和Disabled是用在表单中的两个属性,它们都能够做到使用户不能够更改表单域中的内容。但是它们之间有着微小的差别,总结如下:Readonly只针对input(tex......
  • 2023.11.13
    最唐的一集。A已知质数\(P=10^{18}+31\)的一个原根为\(g=42\),给出\(A\)数组满足\(\displaystyleA_i=\begin{cases}795484359100928850&i=0\\\log_gA_{i-1}\bmodP&i>0\end{cases}\),多次询问\(A_x\)的值。\(1\leT\le10\),\(0\lex\le10^5\)。input:......
  • 使用ES6生成器(Generators)和redux-saga与使用ES2017的async/await和redux-thunk相比的
    内容来自DOChttps://q.houxu6.top/?s=使用ES6生成器(Generators)和redux-saga与使用ES2017的async/await和redux-thunk相比的优缺点。目前关于redux的最新讨论焦点是redux-saga/redux-saga。它使用生成器函数来监听/分发actions。在我深入研究之前,我想了解使用redux-saga与下......
  • 热更新方案探索:如何有效技术选型
    热更新是一种App的更新方式。简单来说,就是在用户下载安装App之后,打开App时对代码和图片等资源进行的即时更新。热更新是App代码逻辑自控发起,无需用户进行手动下载,可以做到用户无感。另外热更新可以做到增量更新,仅需下载更新有修改的代码和资源,可以有效减少更新的时间和数据流量消......