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)的主要内容,如果未能解决你的问题,请参考以下文章