算法(TS):有效的括号

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

  • 左括号必须用相同类型的右括号闭合。
  • 左括号必须以正确的顺序闭合。
  • 每个右括号都有一个对应的相同类型的左括号。

示例 1:

输入:s = "()"

输出:true

示例 2:

输入:s = "()[]{}"

输出:true

示例 3:

输入:s = "(]"

输出:false

提示:

  • 1 <= s.length <= 104
  • s 仅由括号 '()[]{}' 组成

解法

用一个 stack 维护左括号,遍历 s,当发现s[i] 为 左括号时,将其入栈,让发现s[i]为右括号时,判断栈顶是否为与之匹配的左括号,是则出栈,否则不是有效的括号。当遍历结束的时候,判断 stack 的长度,长度为 0 则是有效的括号。

ts 复制代码
function isValid(s: string): boolean {
    const stack:string[] = [],len = s.length
    const pairs = new Map([
        [')', '('],
        [']', '['],
        ['}', '{']
    ]);

    for(let i = 0; i < len ; i++) {
        let item = s[i]
        const top = stack[stack.length - 1]
        
        if (!pairs.has(item)) {
            stack.push(item)
        } else {
            if (top !== pairs.get(item))
                return false
            else {
                stack.pop()
            }
        }
    }
    return stack.length === 0
};

时间复杂度O(n),空间复杂度O(n)

相关推荐
地平线开发者13 小时前
PTQ 量化数值范围与优化
算法·自动驾驶
sali-tec13 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#
测试人社区-小明13 小时前
智能弹性伸缩算法在测试环境中的实践与验证
人工智能·测试工具·算法·机器学习·金融·机器人·量子计算
老前端的功夫13 小时前
Vue 3 性能深度解析:从架构革新到运行时的全面优化
javascript·vue.js·架构
前端 贾公子14 小时前
vue移动端适配方案 === postcss-px-to-viewport
前端·javascript·html
罗西的思考14 小时前
【Agent】MemOS 源码笔记---(5)---记忆分类
人工智能·深度学习·算法
GISer_Jing15 小时前
AI营销增长:4大核心能力+前端落地指南
前端·javascript·人工智能
m0_4711996316 小时前
【场景】前端怎么解决离线收银、数据同步异常等场景问题
前端·javascript
qq_4335545416 小时前
C++数位DP
c++·算法·图论