• LeetCode 20. 有效的括号


    题目:


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

    有效字符串需满足:

    左括号必须用相同类型的右括号闭合。
    左括号必须以正确的顺序闭合。
    注意空字符串可被认为是有效字符串。

    示例 1:

    输入: "()"
    输出: true
    

    示例 2:

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

    示例 3:

    输入: "(]"
    输出: false
    

    示例 4:

    输入: "([)]"
    输出: false
    

    示例 5:

    输入: "{[]}"
    输出: true
    

    思路:

    这个题目很有意思,随便写下几个符合条件的str,你就会发现一个规律,当一个符合要求的str出现的时候,它满足这样的情况:

    "{[]}" "[][{()}][]" "..."
    -->遇见左开右闭就remove,最后剩下的个数必为0,不为0的情况那就是不符合条件返回false
    

    所以,我们是不是可以这样做,从左第一个字符算起,遇见相同的闭字符就remove,经历字符串长度的遍历后如果最后元素为0,那么返回true,否则false。

    方法一:

    class Solution(object):
        def isValid(self, s):
            """
            :type s: str
            :rtype: bool
            """
            res = []
            dict_arr = {")": "(", "}": "{", "]": "["}
            for char in s:
                if char in dict_arr:  
                    if res:  #闭存在且res不为空就remove当前res最后一个元素(开字符)
                        temp = res.pop()
                        if dict_arr[char] !=temp :#特殊情况,"(]"return false
                            return False
                    else: #为空,却找到闭字符,则不符合情况return false
                        return False
                else:
                    res.append(char) #往res添加元素
            return not res
    

    执行用时:16 ms, 在所有 Python 提交中击败了94.28%的用户

    内存消耗:12.7 MB, 在所有 Python 提交中击败了5.00%的用户

  • 相关阅读:
    NET Attribute
    net core HttpClient
    Nuget服务器
    JS-防抖节流
    Codeforces,Topcoder,SGU,Timus,ProjectEuler
    并发编程,高速缓存,原子操作,指令重排序
    C编译器的编译过程主要分成四步: (1) 预处理 (2) 编译 (3) 汇编 (4) 连接
    C#--Distinct
    PageRank算法的思想
    ML.NET 发布0.11版本:.NET中的机器学习,为TensorFlow和ONNX添加了新功能
  • 原文地址:https://www.cnblogs.com/xiaoqiangink/p/13253873.html
Copyright © 2020-2023  润新知