LeetCode_20_简单_有效的括号


1. 题目

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

有效字符串需满足:

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

示例 1:

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

示例 2:

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

示例 3:

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


提示

  • 1 < = s . l e n g t h < = 1 0 4 1 <= s.length <= 10^4 1<=s.length<=104
  • s 仅由括号 '()[]{}' 组成

2. 思路及代码实现(Python)

2.1 栈

判断括号的有效性可以使用「栈」这一数据结构来解决。

我们遍历给定的字符串 s。当我们遇到一个左括号时,我们会期望在后续的遍历中,有一个相同类型的右括号将其闭合。由于后遇到的左括号要先闭合,因此我们可以将这个左括号放入栈顶。

当我们遇到一个右括号时,我们需要将一个相同类型的左括号闭合。此时,我们可以取出栈顶的左括号并判断它们是否是相同类型的括号。如果不是相同的类型,或者栈中并没有左括号,那么字符串 s 无效,返回 False \text{False} False。为了快速判断括号的类型,我们可以使用哈希表存储每一种括号。哈希表的键为右括号,值为相同类型的左括号。

在遍历结束后,如果栈中没有左括号,说明我们将字符串 s 中的所有左括号闭合,返回 True \text{True} True,否则返回 False \text{False} False。注意到有效字符串(只包含括号)的长度一定为偶数,因此如果字符串的长度为奇数,我们可以直接返回 False \text{False} False,省去后续的遍历判断过程。

该算法时间复杂度为 O ( n ) O(n) O(n),其中 n n n 是字符串 s s s 的长度;算法空间复杂度为存储了的字符串长度大小与存储括号总类的哈希表大小之和。

class Solution:
    def isValid(self, s: str) -> bool:
        if len(s) % 2 == 1:
            return False
        
        pairs = {
   
            ")": "(",
            "]": "[",
            "}": "{",
        }
        stack = list()
        for ch in s:
            if ch in pairs:
                if not stack or stack[-1] != pairs[ch]:
                    return False
                stack.pop()
            else:
                stack.append(ch)
        
        return not stack

执行用时:44 ms
消耗内存:16.44 MB

题解来源:力扣官方题解

相关推荐

  1. LeetCode_20_简单_有效括号

    2024-02-20 15:50:01       30 阅读
  2. LeetCode 20. 有效括号

    2024-02-20 15:50:01       37 阅读
  3. Leetcode 20. 有效括号

    2024-02-20 15:50:01       18 阅读
  4. LeetCode 20.有效括号

    2024-02-20 15:50:01       12 阅读
  5. Leetcode 20有效括号

    2024-02-20 15:50:01       13 阅读
  6. LeetCode20题 - 有效括号

    2024-02-20 15:50:01       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-20 15:50:01       14 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-20 15:50:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-20 15:50:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-20 15:50:01       18 阅读

热门阅读

  1. Github 2024-02-19 开源项目日报 Top10

    2024-02-20 15:50:01       29 阅读
  2. RabbitMq相关面试题

    2024-02-20 15:50:01       29 阅读
  3. 用户头像(图片文件)上传(Vue + nodejs 前后端)

    2024-02-20 15:50:01       28 阅读
  4. Chatgpt润色文章“咒语”

    2024-02-20 15:50:01       27 阅读
  5. B3684 [语言月赛202212] 不可以,总司令

    2024-02-20 15:50:01       34 阅读
  6. vue3中不支持.sync语法糖的解决方案

    2024-02-20 15:50:01       29 阅读
  7. FlinkSql一个简单的测试程序

    2024-02-20 15:50:01       24 阅读
  8. Python基础笔记11

    2024-02-20 15:50:01       22 阅读