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

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

内容简介: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%用户)


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

查看所有标签

猜你喜欢:

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

链接

链接

[美]艾伯特-拉斯洛•巴拉巴西 (Albert-László Barabási) / 沈华伟 / 浙江人民出版社 / 2013-8-1 / 59.90元

[内容简介] ★《链接》是《爆发》的作者,艾伯特-拉斯洛•巴拉巴西的成名之作,同时也是复杂网络的奠基之作,社交网络的入门之作。巴拉巴西之前,随机网络理论一直主导者我们的网络思维,是巴拉巴西第一个证明了,我们不是生活在随机世界里,真实网络是无尺度的。 ★巴拉巴西在书中追溯了网络的数学起源,分析了社会学家在此基础上得出的研究成果,最后提出自己的观点:我们周围的复杂网络,从鸡尾酒会、恐怖组织......一起来看看 《链接》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器