内容简介:Given a string containing just the charactersAn input string is valid if:Note that an empty string is also considered valid.
- 英文:
Given a string containing just the characters '('
, ')'
, '{'
, '}'
, '['
and ']'
, determine if the input string is valid.
An input string is valid if:
- Open brackets must be closed by the same type of brackets.
- Open brackets must be closed in the correct order.
Note that an empty string is also considered valid.
- 中文:
给定一个只包括 '('
, ')'
, '{'
, '}'
, '['
, ']'
的字符串,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例
- 示例 1:
输入: "()" 输出: true
- 示例 2:
输入: "()[]{}"
输出: true
- 示例 3:
输入: "(]" 输出: false
- 示例 4:
输入: "([)]" 输出: false
- 示例 5:
输入: "{[]}"
输出: true
题解
- 题解 1
使用栈来实现,检查字符串序列,如果遇到左半边括号,则入栈,如果遇到右半边括号,且栈不为空,则出栈,如果最后栈为空,则表示字符串有效。另外,需考虑特殊情况,即只有右半边括号的情况,这时采用标志位标识这种情况,一旦出现这种情况,字符串无效。
class Solution:
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
stack = []
flag = 1
for i in s:
if i == '(' or i == '{' or i == '[': # 左半边括号入栈
stack.append(i)
elif stack and ((i == ')' and stack[-1] == "(") or (i == '}' and stack[-1] == "{") or (
i == ']' and stack[-1] == "[")): # 遇到右半边括号,且栈不为空
stack.pop()
else: # 标识只有右半边括号的情况
flag = 0
if flag == 0 or stack:
return False
else:
return True
- 题解 2
使用字典存储括号对,依然时左半边括号入栈,遇到右半边括号时,检查栈是否为空,如果为空则表示出现只有右半边括号的七情况,返回 False;如果右半边括号不等于栈顶元素,即括号不对称相等,也返回 False;如果最后栈为空,则表示字符串有效,返回 True,否则,返回 False。
class Solution(object):
def isValid(self, s):
"""
:type s: str
:rtype: bool
"""
if len(s) % 2 != 0: # 过滤括号数量不是偶数的情况
return False
lb = {'(': ')', '[': ']', '{': '}'} # 括号对
stack = []
for x in s:
if x in lb: # 左半边括号入栈
stack.append(x)
else: # 右半边括号
if len(stack) == 0: # 栈内没有左半边括号,字符串无效
return False
top = stack.pop()
if lb[top] != x: # 括号不对称相等
return False
return len(stack) == 0 # 栈为空时则表示字符串有效
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- LeetCode 20. Valid Parentheses
- [swift] LeetCode 20. Valid Parentheses
- LeetCode集锦(六) - 第20题 Valid Parentheses
- Leetcode基础刷题之PHP解析(20. Valid Parentheses)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
你的品牌,价值千万
温迪 / 人民邮电出版社 / 2018-7-1 / 49.00元
“大道无术,万法归心。” 不管是互联网、社交媒体,还是 AI 怎样让人眼花缭乱。从“真心”出发塑造的个人品牌,都将带你从容面对任何一种变化的冲击。现代生活变得越来越透明,如果你不懂得如何真实、精准地定位和呈现自己,你的个人品牌在 碎片信息中被误解、被曲解就是一种必然。 本书分四步引导你剖析自己、发现自我,构建可持续的品牌生态系统,策划品牌战略,提升个人呈现力,并在最后带你勾画出一幅完整的个人......一起来看看 《你的品牌,价值千万》 这本书的介绍吧!