题目来源:
题目分析:
[][][] TRUE
((([]))) TRUE
((([]{}))) TRUE
([{}]) TRUE
([{[][]}]) TRUE
]}]) FALSE
(((( FALSE
)()()( FALSE
那么以 输入字符串((([])))为例子。
第1-3步循环,stack入栈三个左圆括号(, 当前栈顶为左圆括号
第4步循环,stack入栈左方括号[, 当前栈顶为左方括号,栈中元素为1个左方括号。
第5步循环,发现了右方括号,正好和当前栈顶的左方括号[ 满足左右配对,于是弹栈,当前栈顶又变回左圆括号,栈中元素为3个左圆括号。
第6步循环,发现了右圆括号,正好和当前栈顶的左圆括号( 满足左右配对,于是弹栈,当前栈顶依然保持左圆括号,栈中元素为2个左圆括号。
第7步循环,发现了右圆括号,正好和当前栈顶的左圆括号( 满足左右配对,于是弹栈,当前栈顶依然保持左圆括号,栈中元素为1个左圆括号。
第8步循环,发现了右圆括号,正好和当前栈顶的左圆括号( 满足左右配对,于是弹栈,栈中元素为0。
输入字符串的循环体遍历完毕,此时检查stack为空,所以为返回true。
实现代码:
class Solution:
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
sta=[None]
dic={")":"(","}":"{","]":"["}
for t in s:
if(t in dic and dic[t]==sta[len(sta)-1]):
sta.pop()
else:
sta.append(t)
return len(sta) == 1
在python中,我们使用列表来表示堆栈,使用.pop()和.append(x)方法来实现入栈和出栈的操作。这里需要注意的一点是,我们在设置堆栈的时候,并没有将其设置为空列表[],而是[None],这么做的原因是在后面的式子里有减一的操作,而len([])=0;len([None])=1,因此我们需要设置成这样。