内容简介: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)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
计算机真实感图形的算法基础
彭群生 / 科学出版社 / 1999-6 / 45.00元
《计算机真实感图形的算法基础》是系统介绍计算机真实感图形基础理论与算法的一本专著。全书共分九章,包括图形学基础、光照模型原理、简单画面绘制算法、光线跟踪、纹理映射、阴影生成、光能辐射度方法、实时图形绘制技术、自然景物仿真、颜色等。《计算机真实感图形的算法基础》的特点是内容全面,取材新颖,注重算法,力求实用。除系统叙述计算机真实感图形生成的基本概念、基本算法外,作者还注意结合亲身实践体会介绍国内外的......一起来看看 《计算机真实感图形的算法基础》 这本书的介绍吧!