给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
示例 1:
输入:s = "()"
输出:true
示例 2:
输入:s = "()[]{}"
输出:true
示例 3:
输入:s = "(]"
输出:false
示例 4:
输入:s = "([)]"
输出:false
思路概括:
从前向后扫描字符串:
遇到左括号X,就压栈x
遇到右括号y:
如果发现栈顶元素x和该括号y匹配,则栈顶元素出栈,
继续判 断下一个字符; 如果栈顶元素x和该括号不匹配,字符串不匹配,
如果栈为空, 字符串不匹配 扫描完成后,如果栈恰好为空,则字符串匹配,否则,字符串 不匹配
class Solution:
def isValid(self, s: str) -> bool:
stack = []
for ch in s:
if ch in ['(','[','{']:
stack.append(ch)
else:
if stack:
left = stack.pop()
else:
return False
if left == '(' and ch == ')' or left == '{' and ch == "}" or left == "[" and ch==']':
continue
else:
return False
if stack == []:
return True
else:
return False