代码随想录 栈与队列 test 3

20. 有效的括号 - 力扣(LeetCode)

括号序列错误时会出现三种情况:

左括号多余;右括号多余;左右括号不匹配。

解决思路:

遇到左括号,将对应的右括号入栈,遇到右括号则出栈顶元素。因此如果对于情况一,则所有括号遍历完之后有剩余,对于情况2,则此时栈为空,对于情况三,此时出栈元素与遍历的右括号不一致。

代码:

cpp 复制代码
class Solution {
public:
    bool isValid(string s) {
        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();
    }
};
相关推荐
今天不coding2 个月前
算法刷题路线与技巧分享
java·算法·leetcode·秋招·代码随想录·算法通关村·codetop
桃酥4034 个月前
贪心算法day29|134. 加油站(理解有难度)、135. 分发糖果、860. 柠檬水找零、406. 根据身高重建队列
c++·算法·leetcode·贪心算法·代码随想录
upward3378 个月前
代码随想录-算法训练营day55【动态规划16:两个字符串的删除操作、编辑距离、编辑距离总结篇】
java·数据结构·算法·动态规划·代码随想录·算法训练营
upward3378 个月前
代码随想录-算法训练营day40【动态规划03:整数拆分、不同的二叉搜索树】
数据结构·算法·动态规划·力扣·代码随想录·算法训练营
upward3378 个月前
代码随想录-算法训练营day33【贪心算法03:K次取反后最大化的数组和、加油站、分发糖果】
java·数据结构·算法·力扣·代码随想录·算法训练营
upward3379 个月前
代码随想录-算法训练营day24【回溯01:理论基础、组合】
数据结构·算法·二叉树·代码随想录·算法训练营
努力学Java的叶子9 个月前
代码随想录算法训练营Day11 | 20.有效的括号、1047.删除字符串中的所有相邻重复项、150.逆波兰表达式求值
java·数据结构·算法·代码随想录
upward3379 个月前
代码随想录-算法训练营day10【栈与队列01:理论基础、用栈实现队列、用队列实现栈】
java·数据结构·算法·力扣·代码随想录·算法训练营
upward3379 个月前
代码随想录-算法训练营day08【字符串01:反转字符串、替换数字、反转字符串里的单词、右旋转字符串】
java·数据结构·算法·力扣·代码随想录