当前位置:首页 > 力扣 > 用栈结构优雅破解括号匹配难题(力扣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(); // 最终校验所有期待都已满足
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣35:二分法在搜索插入位置中的运用

力扣35:二分法在搜索插入位置中的运用

有序数组的定位在一个严格递增的数字序列中,每个元素都有其确定的位置。当新元素试图加入时,我们需要回答两个问题:它是否已经存在?如果不存在,它应该插入在哪里?这道题要求我们在O(log n)时间内完成这...

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

【深度优先搜索实战】力扣547题:省份数量问题的图论解法

题目解读‌我们面对的是一个典型的图论问题:给定一个城市的连接矩阵,需要计算其中相互连通的城市群(省份)数量。这个问题可以抽象为无向图中的连通分量计算,每个城市代表图中的一个节点,城市之间的连接关系代表...

【动态规划入门】力扣509题:斐波那契数列的经典解法与优化思路

【动态规划入门】力扣509题:斐波那契数列的经典解法与优化思路

题目解读‌斐波那契数列是一个经典的数学问题,在计算机科学中常被用作算法教学的入门案例。这个神奇的数列从0和1开始,后续每个数字都是前两个数字之和。题目要求我们计算第n个斐波那契数,看似简单的问题背后却...

力扣540题:线性扫描法如何高效定位唯一数

力扣540题:线性扫描法如何高效定位唯一数

题目重解一个严格递增的有序数组中,除某个元素外,其余每个元素均出现两次。这个看似简单的条件背后隐藏着巧妙的规律——单一元素会打破数组的"成对对称性"。题目要求以O(log n)时间...

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

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

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

标题:洛谷B3617题解析:八进制转十六进制算法实现与优化(附AC100代码)

一、题目解读洛谷B3617题要求将输入的八进制字符串转换为十六进制表示。题目需处理大数场景,且对输入合法性有明确限制(长度不超过1000,仅包含0-7字符)。由于八进制与十六进制无法直接转换,需借助十...

发表评论

访客

看不清,换一张

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