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();
    • 最后检查栈是否为空,如果为空则表示括号匹配有效,否则无效。
相关推荐
计算机小白一个4 小时前
蓝桥杯 Java B 组之设计 LRU 缓存
java·算法·蓝桥杯
万事可爱^5 小时前
HDBSCAN:密度自适应的层次聚类算法解析与实践
算法·机器学习·数据挖掘·聚类·hdbscan
大数据追光猿7 小时前
Python应用算法之贪心算法理解和实践
大数据·开发语言·人工智能·python·深度学习·算法·贪心算法
Dream it possible!7 小时前
LeetCode 热题 100_在排序数组中查找元素的第一个和最后一个位置(65_34_中等_C++)(二分查找)(一次二分查找+挨个搜索;两次二分查找)
c++·算法·leetcode
夏末秋也凉7 小时前
力扣-回溯-46 全排列
数据结构·算法·leetcode
南宫生7 小时前
力扣每日一题【算法学习day.132】
java·学习·算法·leetcode
柠石榴7 小时前
【练习】【回溯No.1】力扣 77. 组合
c++·算法·leetcode·回溯
Leuanghing7 小时前
【Leetcode】11. 盛最多水的容器
python·算法·leetcode
qy发大财7 小时前
加油站(力扣134)
算法·leetcode·职场和发展
王老师青少年编程7 小时前
【GESP C++八级考试考点详细解读】
数据结构·c++·算法·gesp·csp·信奥赛