题解 | #有效括号序列#
有效括号序列
https://www.nowcoder.com/practice/37548e94a270412c8b9fb85643c8ccc2
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
#
# @param s string字符串
# @return bool布尔型
#
# 用栈来解决,将左括号对应的右括号入栈,每次遇到右括号就从栈顶取出一个元素,若不相同则不合法
# 若遇到右括号而栈先空了,同样违法
# 若遍历完了栈内还有元素,同样违法
class Solution:
def isValid(self , s: str) -> bool:
stack = []
d = {'[':']', '{':'}', '(':')'}
for i in s:
if i in '([{':
stack.append(d[i])
else:
if len(stack) <= 0 or i != stack.pop():
return False
if len(stack) > 0:
return False
return True
