144.栈和队列:有效的括号(力扣)

题目描述

代码解决

cpp 复制代码
class Solution {
public:
    bool isValid(string s) 
    {
        // 如果字符串长度为奇数,不可能是有效的括号字符串
        if(s.size() % 2 != 0) return false;
        
        // 使用栈来存放括号
        stack<char> st;
        
        // 遍历字符串中的每一个字符
        for(int i = 0; i < s.size(); i++)
        {
            // 如果是左括号,则将对应的右括号入栈
            if(s[i] == '(')
            {
                st.push(')');
            }
            else if(s[i] == '{')
            {
                st.push('}');
            }
            else if(s[i] == '[')
            {
                st.push(']');
            }
            // 如果是右括号,检查栈是否为空或栈顶元素是否匹配
            else if(st.empty() || st.top() != s[i])
            {
                return false;
            }
            // 如果栈顶元素匹配当前的右括号,则将栈顶元素弹出
            else
            {
                st.pop();
            }
        }
        
        // 最后检查栈是否为空,如果为空则表示括号匹配有效
        return st.empty();
    }
};
  1. 字符串长度检查

    • if(s.size() % 2 != 0) return false;
    • 如果字符串长度是奇数,直接返回 false,因为括号必须成对出现。
  2. 定义栈

    • stack<char> st;
    • 使用栈来存储括号,方便检查匹配情况。
  3. 遍历字符串

    • for(int i = 0; i < s.size(); i++)
    • 遍历字符串的每一个字符。
  4. 处理左括号

    • if(s[i] == '(') { st.push(')'); }
    • else if(s[i] == '{') { st.push('}'); }
    • else if(s[i] == '[') { st.push(']'); }
    • 如果遇到左括号('(', '{', ''),将对应的右括号(')', '}', '')入栈。
  5. 处理右括号

    • else if(st.empty() || st.top() != s[i])
    • 如果遇到右括号(')', '}', ']'),检查栈是否为空或栈顶元素是否不匹配当前右括号。如果栈为空或不匹配,则返回 false
    • else { st.pop(); }
    • 如果栈顶元素匹配当前右括号,则将栈顶元素弹出。
  6. 检查栈是否为空

    • return st.empty();
    • 最后检查栈是否为空,如果为空则表示括号匹配有效,否则无效。
相关推荐
代码中介商11 分钟前
图论实战:最小生成树与拓扑排序精解
数据结构
Promise微笑15 分钟前
洞察无形:红外热像仪行业标准解析与深度选型指南
网络·人工智能·算法
SHARK_pssm19 分钟前
【数据结构——双向链表】
数据结构·经验分享·笔记·链表
少司府26 分钟前
C++进阶:AVL树
开发语言·数据结构·c++·二叉树·avl树
珠海西格电力29 分钟前
零碳园区的竞争力体现在哪些方面?
大数据·人工智能·算法·架构·能源
孬甭_1 小时前
从基础到优化:深入理解插入排序与希尔排序
数据结构·算法·排序算法
好家伙VCC1 小时前
Rust+Bioinfo:80ms极速SNP注释引擎
java·开发语言·算法·rust
啦哈拉哈1 小时前
【Python】知识点零碎学习7
python·学习·算法
宝贝儿好1 小时前
【NLP】第八章:项目实操案例:文本情感分析
人工智能·python·深度学习·算法·自然语言处理
如竟没有火炬1 小时前
恢复二叉搜索树
数据结构·数据库·python·leetcode·动态规划