news 2026/4/3 1:02:51

力扣热题100 20. 有效的括号

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣热题100 20. 有效的括号

给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。

有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。

  • 示例 1:
  • 输入:s = “()”
  • 输出:true
  • 示例 2:
  • 输入:s = “()[]{}”
  • 输出:true
  • 示例 3:
  • 输入:s = “(]”
  • 输出:false
  • 示例 4:
  • 输入:s = “([])”
  • 输出:true

示例 5:

  • 输入:s = “([)]”
  • 输出:false

这个题目其实是一个阅读理解题,
示例 5:
输入:s = “([)]”
输出:false
这个 示例懂了就行了。
简言之:只要遇见右括号,然后和栈中栈顶数据比较,是一对就返回,不是则不对。即:当前右括号对应的左边 必须在栈顶

public boolean isValid(String s){// 余1 一定是奇数,不成对,返回falseif(s.length()%2==1){returnfalse;}Map<Character, Character>pairs=new HashMap<Character, Character>();pairs.put(')','(');pairs.put(']','[');pairs.put('}','{');Deque<Character>stack=new ArrayDeque<>();for(int i=0;i<s.length();i++){char cur=s.charAt(i);// 如果是左括号,则不包含在pairs 的key 中,入栈。 // 如果是右括号,则包含在pairs 的key 中,判断栈是否为空,为空返回false,否则出栈,判断栈顶元素和当前字符是否匹配,不匹配返回false,匹配则继续循环。if(pairs.containsKey(cur)){if(!stack.isEmpty()){// 如果栈顶元素门和当前字符锁对应的门匹配,则出栈,否则返回false final Character pop=stack.pop();if(pop!=pairs.get(cur)){returnfalse;}}else{returnfalse;}}else{stack.push(cur);}}returnstack.isEmpty();}



为什么字典(Map)里要写成 ‘)’ → ‘(’,而不是 ‘(’ → ‘)’?
🌟 举个例子:“([)]”
看到(→ 开圆门 → 记在心里(入栈)
看到[→ 开方门 → 记在心里(入栈)
👉 现在心里记得:先开了圆门,再开了方门(方门是最新的!)
看到)→ 要关圆门了!
👉 小明立刻查记忆本:
“关)门,应该对应哪个开门动作?”
记忆本说:(
👉 但他心里记得最近开的是方门[
👉[(→ ❌ 配不上!游戏失败!

🔑 关键:只有“关门”的时候才需要查“该配哪个开门动作”,所以字典必须以“关门动作”为 key!

❌ 如果反过来写(错误方式)
假如小明的记忆本写成:

开门动作对应的关门动作
()
[]

那会怎样?
当他看到((开门),他会想:“哦,以后要关)” —— 但这没用!
因为他不知道什么时候关,也不知道关的时候是否匹配。
当他看到)(关门),他查不到!因为字典里没有以)为 key 的记录。
👉 他就不知道该配哪个开门动作!
❌ 完全没法判断!

这个题目很容易理解为:只要字符串中存在对应的右括号(不要求顺序、不要求连续闭合),就算有效”
💡 新题其实变成了:检查每种括号的左、右出现次数是否相等。

🛠️ 解法思路(新题)
不需要栈!只需要计数器:
统计 ‘(’ 和 ‘)’ 的数量
统计 ‘{’ 和 ‘}’ 的数量
统计 ‘[’ 和 ‘]’ 的数量
如果每一对的数量都相等,就返回 true。

/** * 只要字符串中存在对应的右括号(不要求顺序、不要求连续闭合),就算有效 */ public boolean isValid2(String s){if(s.length()%2==1){returnfalse;}int round=0;int square=0;intcurly=0;for(int i=0;i<s.length();i++){char cur=s.charAt(i);if(cur=='(')round++;elseif(cur==')')round--;elseif(cur=='[')square++;elseif(cur==']')square--;elseif(cur=='{')curly++;elseif(cur=='}')curly--;}returnround==0&&square==0&&curly==0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 7:49:07

行政活动策划没思路?数字员工自动出框架,细节自己补

数字员工辅助行政活动策划框架核心思路&#xff1a;利用数字化工具生成基础框架&#xff0c;人工补充个性化细节。以下是可落地的操作方案&#xff1a;智能工具生成基础框架 推荐使用ChatGPT、文心一言等AI工具&#xff0c;输入指令如&#xff1a;"生成一个包含时间轴、预…

作者头像 李华
网站建设 2026/4/1 20:52:45

基于深度学习YOLOv12的石油泄漏检测系统(YOLOv12+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)

一、项目介绍 随着海洋石油开采和运输活动的日益频繁&#xff0c;石油泄漏事故对环境和经济造成的危害愈发严重&#xff0c;亟需高效、精准的检测技术以提升应急响应能力。本文提出了一种基于深度学习YOLOv12的石油泄漏检测系统&#xff0c;该系统结合了前沿的目标检测算法与用…

作者头像 李华
网站建设 2026/3/15 17:44:38

企业微信API二次开发:外部群消息主动推送实操

QiWe开放平台 个人名片API驱动企微自动化&#xff0c;让开发更高效核心能力&#xff1a;为开发者提供标准化接口、快速集成工具&#xff0c;助力产品高效拓展功能场景官方站点&#xff1a;https://www.qiweapi.com团队定位&#xff1a;专注企微API生态的技术服务团队对接通道&…

作者头像 李华
网站建设 2026/3/22 21:58:29

基于深度学习YOLOv12的手机识别检测系统(YOLOv12+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)

一、项目介绍 本文介绍了一个基于YOLOv12深度学习算法的手机目标检测系统&#xff0c;实现了高效、精准的手机识别功能。系统采用YOLOv12模型进行目标检测&#xff0c;并集成用户友好的UI界面&#xff0c;支持登录注册功能&#xff0c;便于用户管理和使用。项目提供完整的Pytho…

作者头像 李华
网站建设 2026/3/19 22:35:20

【开源鸿蒙跨平台开发--KuiklyUI--02】华为云真机部署实战指南

【开源鸿蒙跨平台开发–KuiklyUI–02】华为云真机部署实战指南 更新说明&#xff1a;本文系统梳理 Kuikly 项目打包与云真机部署全流程&#xff0c;新增环境检查清单、常见错误速查表、自动化脚本建议&#xff0c;助你高效完成 Release 版本构建。 &#x1f4cc; 文章概览 适用…

作者头像 李华