[TOC]
題目
給定一個只包括 '('舞骆,')','{'径荔,'}'督禽,'[',']' 的字符串总处,判斷字符串是否有效狈惫。
有效字符串需滿足:
- 左括號必須用相同類型的右括號閉合。
- 左括號必須以正確的順序閉合鹦马。
- 注意空字符串可被認為是有效字符串胧谈。
示例 1:
輸入: "()"
輸出: true
示例 2:
輸入: "()[]{}"
輸出: true
示例 3:
輸入: "(]"
輸出: false
示例 4:
輸入: "([)]"
輸出: false
示例 5:
輸入: "{[]}"
輸出: true
來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/valid-parentheses
著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請聯(lián)系官方授權(quán)荸频,非商業(yè)轉(zhuǎn)載請注明出處菱肖。
解答
class Solution(object):
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
li = []
if s == "":
return True
if len(s) == 0 or s[0] in ')''}'']':
return False
for i in s:
if i in '(''{''[':
li.append(i)
else:
a = ""
if len(li) == 0:
return False
if i == ")":
a = "("
if i == "}":
a = "{"
if i == "]":
a = "["
if li[-1] == a:
li.pop()
else:
return False
if li:
return False
else:
return True
執(zhí)行效果
- 執(zhí)行結(jié)果:通過
- 執(zhí)行用時 :32 ms, 在所有 Python 提交中擊敗了71.50%的用戶
- 內(nèi)存消耗 :11.7 MB, 在所有 Python 提交中擊敗了36.20%的用戶