20.有效的括号 (击败leecode 90%用户)

栏目: IT技术 · 发布时间: 5年前

内容简介:The more you know the more you know you don't know给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。有效字符串需满足:

The more you know the more you know you don't know

题目描述

给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。

左括号必须以正确的顺序闭合。

注意空字符串可被认为是有效字符串。

示例 1:
输入: "()"
输出: true

示例 2:
输入: "()[]{}"
输出: true

示例 3:
输入: "(]"
输出: false

示例 4:
输入: "([)]"
输出: false

示例 5:
输入: "{[]}"
输出: true

解题

思路

  1. 发现字符串为空时,直接返回true

  2. 判断字符串的长度。如果为奇数则直接返回false

  3. 将括号的对应关系存入字典中

  4. 定义一个列表模拟栈数据结构,当字符为右括号时入栈,当字符串为左括号时候出栈

  5. 判断两字符时候相同

代码

class Solution:
    def isValid(self, s: str) -> bool:
        # 是否为空
        if not s:
            return True
        # 是否为奇数
        if len(s) % 2 != 0:
            return False
        # 初始化列表,模拟出栈、入栈
        tmp_list = []
        # 定义括号对应关系
        valid_dict = {
            ")": "(",
            "]": "[",
            "}": "{"
        }
        # 遍历字符串
        for i in s:
            # 如果是左括号则入栈,append到列表的末尾
            if i in ["(", "[", "{"]:
                tmp_list.append(i)
                continue
            # 如果右括号则和列表的末尾对比
            if i in [")", "]", "}"]:
                # 若栈为空,则返回错误
                if not tmp_list:
                    return False
                # 若相同,则从队列中删除末尾的元素
                if tmp_list[-1] == valid_dict[i]:
                    tmp_list.pop()
                    continue
                # 若存在其他字符,直接返回错误
            else:
                return False
        # 返回判断栈是否为空,若空,则返回true,反正返回false
        return not tmp_list

复杂度分析

时间复杂度:O(n),因为我们一次只遍历给定的字符串长度

空间复杂度:O(n),最糟糕的情况是所有的字符串都为左括号,此时所有的字符都需要保存到列表中

20.有效的括号 (击败leecode 90%用户)


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

未来版图

未来版图

麻省理工科技评论 / 人民邮电出版社 / 2018-5-1 / CNY 69.80

《麻省理工科技评论》作为世界上历史悠久、影响力极大的技术商业类杂志,每年都会依据公司的科技领军能力和商业敏感度这两个必要条件,从全球范围内选取50家未来可能会成为行业主导的聪明公司。 这些聪明公司,并非都是行业巨头,甚至专利数量、公司所在地以及资金规模都不在考察范围内。 这些公司是“高精尖科技创新”与“能够保证公司利益* 大化的商业模式”的完 美融合。无论公办私营,无关规模大小,这些遍布全球......一起来看看 《未来版图》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具