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

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

7个月前 (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(); // 最终校验所有期待都已满足
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

牛客DP41精讲:当背包必须装满时,你的状态转移方程该如何调整?

题目重解我们面对一个经典背包问题的变体:给定n个物品,每个物品有重量w和价值v,背包容量为V。需要回答两个问题:1) 普通情况下能获得的最大价值;2) 必须恰好装满背包时的最大价值(若无法装满则输出0...

IOI 1994 洛谷1216:如何用O(1)空间解决数字三角形问题?附代码实现

IOI 1994 洛谷1216:如何用O(1)空间解决数字三角形问题?附代码实现

题目重解:数字三角形是一个经典的动态规划问题,给定一个由数字组成的三角形结构,从顶部出发,每次可以移动到下方相邻的数字,最终到达底部。我们需要找到一条路径,使得路径上经过的数字总和最大。这个问题可以很...

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

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

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

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

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

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

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

洛谷1220题解:动态规划与区间DP优化解法(附代码注释)

一、题目解读洛谷1220题要求计算在n个位置放置灯的情况下,通过关闭连续区间灯并移动至区间端点,使得总耗电量最小。需考虑灯的功率与位置差异,设计高效的算法求解最优策略。二、解题思路1. 动态规划 +...

LeetCode 537题解:复数乘法的C++高效实现与代码解析

LeetCode 537题解:复数乘法的C++高效实现与代码解析

一、题目解读LeetCode 537题要求实现两个复数的乘法,输入为形如"a+bi"的字符串,需输出乘积的复数形式。题目核心在于解析字符串中的实部与虚部,并应用复数乘法公式计算结果...

发表评论

访客

看不清,换一张

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