力扣20. 有效的括号

Problem: 20. 有效的括号

文章目录

题目描述

思路

1.每次遇到左括号将其压入栈顶;

2.遇到右括号:

2.1.先判断当前栈是否为空,若为空则说明不合法;

2.2.弹出当前栈顶元素与当前的右括号配对,若不相互配对,则不合法;
3.最后判读栈是否为空,为空则合法,否则不合法.

复杂度

时间复杂度:

O ( n ) O(n) O(n);其中 n n n为字符串s的长度

空间复杂度:

O ( n ) O(n) O(n)

Code

cpp 复制代码
class Solution {
public:
    /**
     * Valid bracket
     *
     * @param s The given parenthesis string
     * @return bool
     */
    bool isValid(string s) {
        stack<char> stack;
        int len = s.length();
        for (int i = 0; i < len; ++i) {
            if (s[i] == '(' || s[i] == '[' || s[i] == '{') {
                stack.push(s[i]);
            } else {
                if (stack.empty()) {
                    return false;
                } else {
                    char temp = stack.top();
                    stack.pop();
                    if (s[i] == ')' && temp != '(') {
                        return false;
                    }
                    if (s[i] == ']' && temp != '[') {
                        return false;
                    }
                    if (s[i] == '}' && temp != '{') {
                        return false;
                    }
                }
            }
        }
        return stack.empty() ? true : false;
    }
};
相关推荐
.格子衫.39 分钟前
真题卷001——算法备赛
算法
XiaoyaoCarter1 小时前
每日一道leetcode
c++·算法·leetcode·职场和发展·二分查找·深度优先·前缀树
Hygge-star1 小时前
【数据结构】二分查找5.12
java·数据结构·程序人生·算法·学习方法
June`2 小时前
专题二:二叉树的深度搜索(二叉树剪枝)
c++·算法·深度优先·剪枝
好吃的肘子4 小时前
Elasticsearch架构原理
开发语言·算法·elasticsearch·架构·jenkins
胡耀超4 小时前
霍夫圆变换全面解析(OpenCV)
人工智能·python·opencv·算法·计算机视觉·数据挖掘·数据安全
软行4 小时前
LeetCode 每日一题 3341. 到达最后一个房间的最少时间 I + II
数据结构·c++·算法·leetcode·职场和发展
nlog3n4 小时前
Go语言交替打印问题及多种实现方法
开发语言·算法·golang
How_doyou_do4 小时前
备战菊厂笔试4
python·算法·leetcode
朱剑君4 小时前
第九天——贪心算法——非递减数组
算法·贪心算法