当前位置: 首页 > news >正文

【每日算法】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 的代码调试器实时检测语法错误。
  • 表单验证:复杂表达式输入(如规则引擎)需确保括号正确。
http://www.cnnetsun.cn/news/103572.html

相关文章:

  • Photoshop图层批量导出终极指南:10倍效率提升的完整教程
  • 【每日算法】LeetCode 739. 每日温度:从暴力遍历到单调栈的优雅解决
  • Golin终极指南:网络安全扫描与等保核查的完整解决方案
  • 77、由于您仅提供了“以下”两个字,没有具体的英文内容,所以我无法按照要求为您生成博客,请您提供完整的英文内容。
  • Grafana中文版终极指南:快速搭建专业数据可视化监控平台
  • 4、Mac OS X系统使用指南:从Launchd到Shell操作
  • 6、Mac OS X 文件操作全攻略
  • XXPermissions深度解析:Android权限框架的架构揭秘与实践指南
  • PDF翻译格式错乱终极解决方案:三步实现完美排版修复
  • 41、深入了解 IPv6:从基础到实践
  • 47、搭建 Linux 拨号服务器与网络故障排查全攻略
  • 3步轻松掌控电脑风扇:FanControl免费调校完整教程
  • 49、网络故障排查工具大全及使用指南
  • WordPress导入pdf识别图表生成代码片段
  • WordPress支持wps文档导入保留格式样式
  • 开源AI编程工具的商业化破局:Continue的可持续生态构建
  • UVa 12619 Just Make A Wish
  • 直播间数据监控终极指南:如何快速获取弹幕、礼物与用户行为数据
  • CellProfiler生物图像分析完全指南:从入门到精通
  • B站视频下载完全指南:新手必备的简单三步教程
  • KISS FFT:重新定义轻量级信号处理的工程艺术
  • 6、常见WRT54G第三方固件全解析
  • 3步构建企业级3D抽奖系统:从策划到落地的完整解决方案
  • LDDC:3大平台歌词获取,打造专属音乐体验
  • EmotiVoice是否内置语音质量检测模块?MOS预估功能上线
  • EmotiVoice能否用于外语学习跟读训练?发音准确性评估
  • 从零开始的编程冒险:游戏化学习如何让你爱上写代码
  • NocoDB云原生部署实战:构建企业级低代码数据平台
  • drawio-libs:重新定义专业图表绘制的智能图标生态
  • Vue-CodeMirror6 完整配置与最佳实践指南