0
点赞
收藏
分享

微信扫一扫

18. Leetcode 20. 有效的括号 (栈)

给定一个只包括 '(',')','{','}','[',']' 的字符串 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
            
举报

相关推荐

0 条评论