0020. Valid Parentheses (leetcode in python day6)


一、多个并列的if条件句和if-elif的区别

多个并列if条件句:程序会对每一个if条件句都执行。判断条件真假,为真时,执行if后面的语句块;然后再接着对下一个if条件句进行判断,再执行
if-elif:不是并列关系,依次判断,当条件为真执行语句块后,退出判断,不会再执行接下来的elif语句。
在这里插入图片描述
原文链接:多个并列的if条件句和if-elif的区别


二、python中的栈

定义:栈是一个特殊的有序列表,其插入和删除操作都在一端(栈顶)进行。

栈的接口:
push():入栈, pop():出栈, isempty():判断是否是空栈, length():栈的长度, gettop():取栈顶元素

s = []
#入栈
s.append()

#出栈
s.pop()

#判断是否为空栈
not s

#栈的长度
len(s)

#取栈顶元素
s[-1]

原文链接:python中的栈


三、solution

class Solution:
    def isValid(self, s: str) -> bool:

        stack = []
        lookup = {"(": ")", "{": "}", "[": "]"}
        for parenthese in s:
            if parenthese in lookup:  #for example s = "{[]}", just "{[" will be appended to stack
                stack.append(parenthese)
            elif len(stack) == 0 or lookup[stack.pop()] != parenthese: #"[{]}", while parenthese is ], stack.pop is {
                return False
            # add len(stack) != 0 to avoid situation like s = "]"    
        
        # avoid s = "["
        return len(stack) == 0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值