LeetCode 20. 有效的括号
题目:
给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()"
输出: true
示例 2:
输入: "()[]{}"
输出: true
示例 3:
输入: "(]"
输出: false
示例 4:
输入: "([)]"
输出: false
示例 5:
输入: "{[]}"
输出: true
思路:
这个题目很有意思,随便写下几个符合条件的str,你就会发现一个规律,当一个符合要求的str出现的时候,它满足这样的情况:
"{[]}" "[][{()}][]" "..."
-->遇见左开右闭就remove,最后剩下的个数必为0,不为0的情况那就是不符合条件返回false
所以,我们是不是可以这样做,从左第一个字符算起,遇见相同的闭字符就remove,经历字符串长度的遍历后如果最后元素为0,那么返回true,否则false。
方法一:
class Solution(object):
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
res = []
dict_arr = {")": "(", "}": "{", "]": "["}
for char in s:
if char in dict_arr:
if res: #闭存在且res不为空就remove当前res最后一个元素(开字符)
temp = res.pop()
if dict_arr[char] !=temp :#特殊情况,"(]"return false
return False
else: #为空,却找到闭字符,则不符合情况return false
return False
else:
res.append(char) #往res添加元素
return not res
执行用时:16 ms, 在所有 Python 提交中击败了94.28%的用户
内存消耗:12.7 MB, 在所有 Python 提交中击败了5.00%的用户
Knowledge, like candlelight, can illuminate a person and countless people.