博客
关于我
LeetCode--020--括号匹配
阅读量:793 次
发布时间:2023-01-31

本文共 742 字,大约阅读时间需要 2 分钟。

为了判断一个包含不同类型括号的字符串是否有效,我们可以使用栈数据结构。栈可以帮助我们跟踪括号的顺序,确保每个左括号都能被正确闭合。

输入包括六种括号字符:'('、')'、'{'、'}'、'['、']'。有效字符串要求左括号必须以正确的顺序和类型闭合。具体来说:

  • 每次遇到左括号,压入栈。
  • 每次遇到右括号,检查栈是否为空:
    • 如果栈为空,字符串无效。
    • 如果栈不为空,弹出栈顶字符,检查是否对应正确的左括号。
  • 遍历完整个字符串后,栈必须为空才表示闭合顺序正确。
  • 实现代码:

    class Solution:    def isValid(self, s: str) -> bool:        stack = []        for c in s:            if c in '({[':                stack.append(c)            elif c in ')]}':                if not stack:                    return False                top = stack.pop()                if (c == ')' and top != '(') or (c == '}' and top != '{') or (c == ']' and top != '['):                    return False        return len(stack) == 0

    这个方法通过遍历字符串一次,检查每个字符是否正确闭合,从而确保字符串的有效性。逻辑简单且效率高,时间复杂度为 O(n),其中 n 是字符串的长度。

    转载地址:http://vlgyk.baihongyu.com/

    你可能感兴趣的文章
    LibTorch与MFC
    查看>>
    libtorch中python中cuda可以使用,但是是c++环境中不行
    查看>>
    LibTorch中TensorOptions的使用
    查看>>
    LibTorch之DataSet数据集处理方法
    查看>>
    LibTorch之优化器
    查看>>
    LibTorch之全连接层(torch::nn::Linear)使用
    查看>>
    LibTorch之图像分类
    查看>>
    LibTorch之张量操作与线性回归
    查看>>
    LibTorch之损失函数
    查看>>
    LibTorch之激活函数层
    查看>>
    LibTorch之网络层中的卷积层
    查看>>
    LibTorch之网络模型构建
    查看>>
    Libtorch在vs中c++相关配置
    查看>>
    LibTorch实现LeNet
    查看>>
    LibTorch实现MLP(多层感知机)
    查看>>
    Libtorch常用代码
    查看>>
    LibTorch框架学习
    查看>>
    libtorch组成讲解之ATen、c10、at、csrc
    查看>>
    libvirt TLS
    查看>>
    libvirtd tcp 方式远程连接配置步骤
    查看>>