news 2026/6/24 23:23:24

【每日算法】LeetCode 20. 有效的括号

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【每日算法】LeetCode 20. 有效的括号

对前端开发者而言,学习算法绝非为了“炫技”。它是你从“页面构建者”迈向“复杂系统设计者”的关键阶梯。它将你的编码能力从“实现功能”提升到“设计优雅、高效解决方案”的层面。从现在开始,每天投入一小段时间,结合前端场景去理解和练习,你将会感受到自身技术视野和问题解决能力的质的飞跃。------ 算法:资深前端开发者的进阶引擎

LeetCode 20. 有效的括号:前端开发者的解析与实现

1. 题目描述

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

  1. 左括号必须用相同类型的右括号闭合。
  2. 左括号必须以正确的顺序闭合。

示例:

  • 输入:s = "()",输出:true
  • 输入:s = "()[]{}",输出:true
  • 输入:s = "(]",输出:false
  • 输入:s = "([)]",输出:false
  • 输入:s = "{[]}",输出:true

2. 问题分析

这是一个经典的括号匹配问题,在前端开发中广泛存在类似场景,例如:

  • HTML/XML 标签闭合检查:确保<div></div>正确匹配。
  • 代码编辑器语法高亮:在 JavaScript、CSS 或模板字符串中验证括号、引号是否成对。
  • 表达式求值:如解析 JSON、计算算术表达式(如(1 + 2) * 3)时,需先验证括号有效性。

问题核心在于顺序匹配:后出现的左括号需先匹配右括号,这天然契合栈(Stack)的 LIFO(后进先出)特性。因此,栈是最优数据结构选择。

3. 解题思路

解决此问题主要有两种思路:暴力替换法和栈方法。栈方法是最优解,因其时间复杂度和代码可读性俱佳。

3.1 暴力法(替换法)

  • 思路:不断循环替换字符串中成对的括号(如"()""[]""{}")为空字符串,直到字符串不再变化。若最终字符串为空,则有效;否则无效。
  • 复杂度:时间复杂度 O(n^2)(每次替换可能需遍历整个字符串),空间复杂度 O(1)。效率低,不推荐用于生产环境。

3.2 栈方法(最优解)

  • 思路:遍历字符串,使用栈存储左括号;遇到右括号时,检查栈顶左括号是否匹配。若匹配则弹出栈顶,继续;否则无效。遍历结束后,栈应为空才有效。
  • 复杂度:时间复杂度 O(n),空间复杂度 O(n)(最坏情况栈存储所有字符)。这是最优解,因其一次遍历即可解决。

4. 代码实现

4.1 暴力法实现

functionisValid(s){while(s.includes('()')||s.includes('[]')||s.includes('{}')){s=s.replace('()','').replace('[]','').replace('{}','');}returns==='';}

4.2 栈方法实现

functionisValid(s){conststack=[];constmap={'(':')','[':']','{':'}'};for(letcharofs){if(map[char]){// 左括号入栈stack.push(char);}else{// 右括号检查匹配consttop=stack.pop();if(map[top]!==char){returnfalse;}}}// 栈为空表示所有括号匹配returnstack.length===0;}

5. 复杂度与优缺点对比

思路时间复杂度空间复杂度优点缺点适用场景
暴力法O(n^2)O(1)代码简单,无需额外数据结构效率低,字符串替换开销大小规模数据或学习演示
栈方法O(n)O(n)高效,一次遍历;易于扩展需额外空间存储栈生产环境,如前端解析、编辑器校验

6. 总结

实际应用场景:

  • 前端框架:Vue/React 的模板编译时,需检查标签和指令的括号匹配。
  • 构建工具:Babel、Webpack 在解析 JavaScript AST 时,依赖括号验证。
  • 开发工具:VS Code、Chrome DevTools 的代码调试器实时检测语法错误。
  • 表单验证:复杂表达式输入(如规则引擎)需确保括号正确。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 17:20:45

71、量子容错计算:原理、设计与应用

量子容错计算:原理、设计与应用 1. 量子容错电路概述 在量子计算领域,故障指的是系统中出现的错误,它会使系统偏离正常运行状态。量子容错的目的是在计算机基本组件不可靠的情况下,仍能实现可靠的量子计算。 1.1 量子纠错编码 为实现这一目标,计算机中的量子比特(qub…

作者头像 李华
网站建设 2026/6/24 15:13:19

Obsidian Linter终极教程:从零开始掌握笔记格式化艺术

Obsidian Linter终极教程&#xff1a;从零开始掌握笔记格式化艺术 【免费下载链接】obsidian-linter An Obsidian plugin that formats and styles your notes with a focus on configurability and extensibility. 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-li…

作者头像 李华
网站建设 2026/6/24 23:48:41

UVa 10546 The Eagle‘s Nest

题目翻译与分析 游戏规则理解 《鹰巢》是一款非线性剧情的动作冒险游戏。玩家需要从简单任务开始&#xff0c;通过完成越来越难的任务&#xff0c;最终挑战最困难的任务。游戏的核心机制如下&#xff1a; 任务难度与顺序 &#xff1a;每个任务有一个难度值&#xff0c;任务按输…

作者头像 李华
网站建设 2026/6/25 13:52:52

WordPress导入pdf支持文本搜索与高亮

要求&#xff1a;开源&#xff0c;免费&#xff0c;技术支持 博客&#xff1a;WordPress 开发语言&#xff1a;PHP 数据库&#xff1a;MySQL 功能&#xff1a;导入Word,导入Excel,导入PPT(PowerPoint),导入PDF,复制粘贴word,导入微信公众号内容,web截屏 平台&#xff1a;Window…

作者头像 李华
网站建设 2026/6/24 10:31:50

WordPress粘贴word超链接自动解析域名

要求&#xff1a;开源&#xff0c;免费&#xff0c;技术支持 博客&#xff1a;WordPress 开发语言&#xff1a;PHP 数据库&#xff1a;MySQL 功能&#xff1a;导入Word,导入Excel,导入PPT(PowerPoint),导入PDF,复制粘贴word,导入微信公众号内容,web截屏 平台&#xff1a;Window…

作者头像 李华
网站建设 2026/6/25 17:03:40

Locale Remulator 终极指南:轻松实现多语言环境模拟

Locale Remulator 终极指南&#xff1a;轻松实现多语言环境模拟 【免费下载链接】Locale_Remulator System Region and Language Simulator. 项目地址: https://gitcode.com/gh_mirrors/lo/Locale_Remulator 在全球化的软件开发过程中&#xff0c;测试不同地区设置下的应…

作者头像 李华