内容简介: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)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Python编程
[美]埃里克·马瑟斯 / 袁国忠 / 人民邮电出版社 / 2016-7-1 / CNY 89.00
本书是一本针对所有层次的Python 读者而作的Python 入门书。全书分两部分:第一部分介绍用Python 编程所必须了解的基本概念,包括matplotlib、NumPy 和Pygal 等强大的Python 库和工具介绍,以及列表、字典、if 语句、类、文件与异常、代码测试等内容;第二部分将理论付诸实践,讲解如何开发三个项目,包括简单的Python 2D 游戏开发如何利用数据生成交互式的信息图......一起来看看 《Python编程》 这本书的介绍吧!