LeetCode20——有效的括号(python)

Posted 归止于飞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode20——有效的括号(python)相关的知识,希望对你有一定的参考价值。

给定一个只包括 ‘(’,’)’,’’,’’,’[’,’]’ 的字符串 s ,判断字符串是否有效。有效字符串需满足:

1、左括号必须用相同类型的右括号闭合。
2、左括号必须以正确的顺序闭合。

解法1

思路:将程序中的“()”、“[]”、““三种括号用” “代替,即空字符,如果最后剩下为空集,则确定为有效,非空集即为无效。

首先我们要知道怎么使用replace函数:

str.replace(old, new[, max])
  • old – 将被替换的子字符串。
  • new – 新字符串,用于替换old子字符串。
  • max – 可选字符串, 替换不超过 max 次
class Solution:
    def isValid(self, s):
        while '' in s or '()' in s or '[]' in s:
            s = s.replace('', '')
            s = s.replace('[]', '')
            s = s.replace('()', '')
        if s == '':
            return True
        else:
            return False

解法2

思路:栈先入后出特点恰好与本题括号排序特点一致,即若遇到左括号入栈,遇到右括号时将对应栈顶左括号出栈,则遍历完所有括号后 stack 仍然为空;建立哈希表 dic 构建左右括号对应关系:keykey 左括号,valuevalue 右括号;这样查询 22 个括号是否对应只需 O(1)O(1) 时间复杂度;建立栈 stack,遍历字符串 s 并按照算法流程一一判断。

知识点;哈希表,栈,pop()与append运用。

class Solution:
    def isValid(self, s):
        dic = '': '', '[': ']', '(': ')','1':'1'
        stack = ['1']
        for c in s:
            if c in dic:
                stack.append(c)
            elif dic[stack.pop()] != c:
                return False
        return len(stack) == 1

以上是关于LeetCode20——有效的括号(python)的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode20——有效的括号(python)

Python描述 LeetCode 20. 有效的括号

Leetcode刷题Python20. 有效的括号

Leetcode 20有效的括号(附JAVA Deque 和LinkedList用法)

LeetCode刷题20-简单-有效的括号

LeetCode刷题20-简单-有效的括号