当前位置:首页 > 力扣 > 用栈结构优雅破解括号匹配难题(力扣20题)

用栈结构优雅破解括号匹配难题(力扣20题)

3个月前 (05-15)

用栈结构优雅破解括号匹配难题(力扣20题) 字符串 栈 数据结构 力扣 算法 C++ 迭代 第1张

一、题目重新解读

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

1. 左括号必须与相同类型的右括号闭合(如 () 对应,[] 对应,{} 对应);

2. 闭合顺序必须正确(先开的括号后闭);

3. 不存在未匹配的括号。



二、解题思路与过程

1. 栈结构特性:“后进先出(LIFO)”的特性天然适配括号匹配——后出现的左括号需先被匹配。

2. 遍历策略:

    1.遇左括号直接压栈,记录“待匹配项”;

    2.遇右括号时:

    3.若栈空,说明右括号无对应左括号(如 ])),直接返回假;

    4.若栈顶左括号与当前右括号不匹配(如 ][),返回假;

    5.匹配成功则弹栈,继续下一字符。

3. 最终判断:遍历结束后,栈为空说明所有括号均匹配,否则存在剩余左括号(如 (])。


三、代码与注释

class Solution {
public:
    // 判断字符是否为左括号的优雅舞步
    bool IsLift(char a) {
        return a == '(' || a == '[' || a == '{'; // 简洁的三重判断
    }

    bool isValid(string s) {
        if(s.size()&1) return false; // 奇数长度直接谢幕

        stack<char> s1; // 创建记忆栈
        for(int i=0; i<s.size(); i++) {
            if(IsLift(s[i])) {
                s1.push(s[i]); // 收集未完成的期待
            } else {
                if(s1.empty()) return false; // 空栈遇右括号必定失格
                
                // 检查栈顶元素是否与当前右括号共鸣
                if( (s1.top()=='(' && s[i]==')') || 
                    (s1.top()=='[' && s[i]==']') ||
                    (s1.top()=='{' && s[i]=='}') ) {
                    s1.pop(); // 成功配对则释放栈顶
                } else {
                    return false; // 不和谐音出现
                }
            }
        }
        return s1.empty(); // 最终校验所有期待都已满足
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣746:三步通关最小花费爬楼梯

力扣746:三步通关最小花费爬楼梯

题目解析:站在楼梯的某个台阶时,需要支付当前台阶对应的体力值cost[i],之后可以选择向上爬1或2个台阶。最终目标是到达‌楼层顶部‌(即数组末尾之后的位置),且初始位置可选择下标0或1的台阶作为起点...

力扣第654题:最大二叉树解题教程 用数组构造最大二叉树

力扣第654题:最大二叉树解题教程 用数组构造最大二叉树

题目解读给定一个不含重复元素的整数数组,我们需要构建一棵最大二叉树。构建规则是:数组中的最大值作为根节点,其左侧子数组构建左子树,右侧子数组构建右子树,然后递归地应用这个规则。这种构建方式体现了分治思...

力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界

力扣501题最优解:不用额外空间找出BST中的众数?这个解法让你大开眼界

题目解读‌:在二叉搜索树的世界里,每个节点都默默记录着自己的数值。现在我们需要找出这些数值中出现频率最高的那些数字,也就是所谓的"众数"。有趣的是,二叉搜索树本身具有左小右大的特性...

手把手教你实现头插法树:从代码到原理的深度解析

一、简介和特点头插法树是一种基于链表实现的树形数据结构,其核心思想是通过链表头插法管理节点的孩子节点。在本文的代码示例中,我们使用C++模板类实现了树结构,每个树节点(treenode<T>...

牛客14496题解:括号最大深度问题(栈思想与代码优化)

牛客14496题解:括号最大深度问题(栈思想与代码优化)

一、题目解读牛客14496题要求计算给定括号字符串中的最大深度。例如,对于字符串 "(()())",最大深度为2。题目考察对括号嵌套结构的理解,以及如何通过编程找到最深嵌套层次。二...

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

一、题目解读力扣3112题要求解决带时间限制的最短路径问题:给定一个有向图,节点具有消失时间,需计算从起点到各节点的最短路径,且路径总时间不能超过节点的消失时间。题目难点在于需在传统最短路径算法(如D...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。