Skip to main content

20. 有效的括号 [easy]

20. 有效的括号 [easy]

https://leetcode-cn.com/problems/valid-parentheses/

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

有效字符串需满足:

  • 左括号必须用相同类型的右括号闭合。
  • 左括号必须以正确的顺序闭合。
  • 注意空字符串可被认为是有效字符串。

示例 1:

输入: "()"
输出: true

示例 2:

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

示例 3:

输入: "(]"
输出: false

示例 4:

输入: "([)]"
输出: false

示例 5:

输入: "{[]}"
输出: true

通过次数306,932 | 提交次数733,967

First Try

2020-06-24

经过0032的hard题目后再来做这个题目,就是轻轻松松,用栈解决即可。

class Solution(object):
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
mop = {")": "(", "]": "[", "}": "{"}
pushin = set(mop.values())
stack = []
for i in s:
if i in pushin:
stack.append(i)
else:
if len(stack) and stack.pop() == mop[i]:
continue
return False
return len(stack) == 0
  • 执行用时:28 ms, 在所有 Python 提交中击败了44.38%的用户
  • 内存消耗:12.6 MB, 在所有 Python 提交中击败了5.00%的用户