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

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

一句话:

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

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

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

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

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

完整解题步骤

  1. 边界预判 :如果字符串长度是奇数,直接返回 false(括号必须成对出现)
  2. 建立映射:用哈希表存储 "右括号 → 对应左括号" 的映射,方便快速查找
  3. 遍历字符串
    • 遇到左括号 → 压入栈
    • 遇到右括号:
      • 如果栈为空(没有对应的左括号)→ 返回 false
      • 如果栈顶的左括号和当前右括号不匹配 → 返回 false
      • 如果匹配 → 弹出栈顶
  4. 最终检查 :遍历结束后,如果栈为空,说明所有左括号都匹配成功;否则有剩余左括号没匹配,返回 false
cpp 复制代码
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(); //最后看看最后的栈是否为空 如果是空说明都匹配了 所以是真的;如果不为空 说明有剩余 说明假的
    }
};
相关推荐
罗超驿5 小时前
9.LeetCode 209. 长度最小的子数组 | 滑动窗口专题详解
java·算法·leetcode·面试
孟林洁6 小时前
Java转AI应用开发速成(3)—— 第一个 SpringAI 聊天应用
java·spring boot·后端·ai·机器人
Simon523146 小时前
Spring AOP 五大通知类型
java·前端·spring
早睡身体真不戳6 小时前
【无标题】
java·服务器·windows
布吉岛的石头6 小时前
Java 程序员第 38 阶段:Embedding 向量缓存实战,减少重复向量化计算开销
java·缓存·embedding
Circ.6 小时前
Java 远程调用 NX 11 完整实战:参数读取、修改、STP 文件导出(附环境配置 + 源码)
java·开发语言·nx11
2401_833269306 小时前
【无标题】
java·开发语言
宇宙realman_9996 小时前
420B污染度等级查询代码
java·开发语言·算法
小白学大数据6 小时前
Playwright 爬虫:Python 爬取 JS 渲染的 JSP 网站
开发语言·javascript·爬虫·python·数据分析