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

力扣hot100(37)栈-有效的括号

核心思想:为什么必须用栈?

一句话:

括号的闭合规则 = 栈的 "后进先出" 规则

后遇到的左括号,必须最先被闭合。 比如([)]

  • 先遇到(,再遇到[
  • 接下来遇到),应该先闭合最后遇到的[,但这里闭合了(,所以错误

栈正好完美匹配这个逻辑:

  • 遇到左括号 → 压入栈顶(后遇到的在最上面)
  • 遇到右括号 → 弹出栈顶的左括号,检查是否匹配。

完整解题步骤

  1. 边界预判:如果字符串长度是奇数,直接返回false(括号必须成对出现)
  2. 建立映射:用哈希表存储 "右括号 → 对应左括号" 的映射,方便快速查找
  3. 遍历字符串
    • 遇到左括号 → 压入栈
    • 遇到右括号:
      • 如果栈为空(没有对应的左括号)→ 返回false
      • 如果栈顶的左括号和当前右括号不匹配 → 返回false
      • 如果匹配 → 弹出栈顶
  4. 最终检查:遍历结束后,如果栈为空,说明所有左括号都匹配成功;否则有剩余左括号没匹配,返回false
class Solution { public: bool isValid(string s) { int n = s.size(); //如果是奇数肯定不成对 直接返回false if(n%2 == 1){ return false; } //哈希表维护正常的配对 //右括号当键 unordered_map<char,char> pairs = { {')','('}, {']','['}, {'}','{'} }; stack<char> stk; //遍历这个s 遇到左括号就入栈 遇到右括号就和栈顶匹配 for(char ch:s){ if(pairs.count(ch)){//判断ch这个键存不存在 也就是是不是右括号 //如果哈希表里有ch当前这个字符 //如果当前栈为空(那就没有匹配的) 或者栈顶不等于当前元素的另一半 if(stk.empty()||stk.top()!= pairs[ch]){ return false; } //否则就是匹配上了 那就弹出栈顶 stk.pop(); } else{//如果不是右括号 那就入栈 stk.push(ch);} } return stk.empty(); //最后看看最后的栈是否为空 如果是空说明都匹配了 所以是真的;如果不为空 说明有剩余 说明假的 } };
http://www.jsqmd.com/news/904641/

相关文章:

  • 山东省# 平度寄件不花冤枉钱!2026全国靠谱快递平台实测,这4个闭眼冲 - 时讯资讯
  • 基于Arduino与压电传感器的DIY防盗报警器制作全攻略
  • BJT双晶体管自锁开关:实现纳安级待机功耗的智能电源管理方案
  • 从注塑机到锂电装备:布伦特包装重型设备木箱的承重科学与实战密码 - 资讯焦点
  • Scrapy中间件:编写Downloader Middleware实现随机UA和代理。手把手教你打造Scrapy智能中间件:随机UA与代理池实战,爬虫再也不怕被封
  • Claude响应延迟飙升?3步定位GPU内存泄漏并实现47%吞吐量提升
  • 保姆级教程:在Ubuntu 20.04上跑通Autoware 1.14官方Demo(含rqt_tf_tree缺失修复)
  • 嘉兴靠谱黄金回收门店精选|专业鉴定・免费上门・透明结算,2026 年 5 月 28 日金价实时同步 - 润富黄金珠宝行
  • 【Sora 2内容安全红线白皮书】:工信部备案新规下,6类高危提示词自动触发审核拦截(附检测工具包)
  • Linux服务器上PCIe错误处理模式怎么选?从Firmware First到OS Native的实战配置与日志分析
  • 多线程爬虫进阶:使用concurrent.futures模块实现海量图片极速下载
  • Spring Boot整合Flowable实战:启动时79张表自动生成的背后逻辑与自定义配置
  • 频繁漏评丢粉丝?自媒体自动回复解决私信评论难题 - 资讯焦点
  • 2026年苏州黄金回收靠谱推荐:5家实测+全流程避坑攻略 - 天天生活分享日志
  • 从模糊到完美:5分钟掌握Vectorizer终极图像矢量化秘籍
  • 跨模态目标检测架构设计:GroundingDINO实战应用解析
  • 异步协程:使用aiohttp + asyncio实现高并发请求。异步协程实战:使用aiohttp+asyncio打造每秒请求数破千的Python爬虫
  • XC16X快速寄存器组切换技术优化中断响应
  • 告别卡顿!用Wayland+Weston打造丝滑Linux桌面,保姆级配置与避坑指南
  • JS逆向|猿人学逆向反混淆练习平台第10题加密分析
  • 内存泄漏排查实战
  • 苏州翡翠回收避坑攻略!2026实测6家门店,远离低价隐形套路 - 薛定谔的梨花猫
  • 多进程爬虫:利用多核CPU分别爬取不同的板块。多进程爬虫实战:利用多核CPU并发爬取多个板块,性能提升500%
  • 555定时器无稳态多谐振荡器:从原理到频率调制的实践指南
  • GRBL-Plotter:从创意到成品的数字制造桥梁
  • GBKtoUTF-8:高效解决中文乱码的终极编码转换工具
  • SpringBoot + RuoYi + 达梦数据库整合实战:一份完整的application.yml配置清单与SQL改写手册
  • 广州小红书代运营公司排名及联系方式——广州市壹起航科技有限公司:17年全网营销积淀,打造小红书实效代运营行业标杆(更新时间:2026-05-27 23:16:59) - 趣谈科技事物
  • 生产者消费者模式:使用Queue标准库构建生产者消费者爬虫模型。深度实战:基于Queue标准库的生产者消费者爬虫模型,打造高并发分布式采集系统
  • 超越基础:为你的Unity小地图加入高级功能(雷达扫描、迷雾探索、多目标标记)