【面试经典150 | 栈】有效的括号

文章目录

Tag

【栈】


题目来源

20. 有效的括号


题目解读

括号有三种类型,分别是小括号、中括号和大括号,每种括号的左右两半括号必须一一对应才是有效的括号,如果某一种括号之间穿插者其他的闭合的括号,那么这个括号字符串也是有效的,比如 "({[]})" 就是一个有效的括号字符串。

现在给你一个仅有括号组成的字符串,判断该字符串是否是有效的字符串。


解题思路

方法一:栈+哈希表

本题使用栈来解决,我们可以边更新栈边在栈中找闭合的括号。

我们遍历字符串,如果栈为空,我们自然是要将当前的括号字符加入到栈中的,继续遍历字符串:

  • 当遇到的括号是右括号时,我们希望可以找到一个相同类型的左括号,于是如果栈顶的括号是对应类型的左括号,那么我们就将栈顶匹配的左括号弹出站;如果栈顶的括号不是对应类型的左括号,则当前遍历的括号无法闭合,那么该符号字符串不是有效的字符串,直接返回 false
  • 当遇到的括号是左括号字符串时,直接将当前字符入栈;
  • 遍历完字符串,如果最后栈为空,则该字符串是有效的字符串,直接返回 true;否则返回 false

在判断当前遍历的字符是否是右括号时,可以使用哈希表。具体地,定义一个键为右括号字符,值为对应的左括号字符的哈希表 pairs。在遍历字符串时,如果当前字符在哈希表的键中,可以使用 pairs.count() 或者 pairs.find() 来查找当前字符是否是右括号;如果当前字符是右括号,那么还可以使用哈希表来查找栈顶元素是否是左括号。

特别的,如果字符串的长度为奇数,那么该字符串一定不是有效的括号字符串。

实现代码

cpp 复制代码
class Solution {
public:
    bool isValid(string s) {
        int n = s.size();
		if (n % 2 == 1)
			return false;

		unordered_map<char, char> pairs = {
			{')', '('},
			{']', '['},
			{'}', '{'}
		};

		stack<char> st;
		for (auto ch : s) {
			if (pairs.count(ch)) {
				if (st.empty() || st.top() != pairs[ch])
					return false;
				st.pop();
			}
			else st.push(ch);
		}
		return st.empty();
    }
};

复杂度分析

时间复杂度: O ( n ) O(n) O(n), n n n 为字符串 s 的长度。

空间复杂度: O ( n ) O(n) O(n)。


其他语言

c

c 复制代码
char pairs(char a) {
    if (a == '}') return '{';
    if (a == ']') return '[';
    if (a == ')') return '(';
    return 0;
}

bool isValid(char* s) {
    int n = strlen(s);
    if (n % 2 == 1) {
        return false;
    }
    int stk[n + 1], top = 0;
    for (int i = 0; i < n; i++) {
        char ch = pairs(s[i]);
        if (ch) {
            if (top == 0 || stk[top - 1] != ch) {
                return false;
            }
            top--;
        } else {
            stk[top++] = s[i];
        }
    }
    return top == 0;
}

python3

py3 复制代码
class Solution:
    def isValid(self, s: str) -> bool:
        if len(s) % 2 == 1:
            return False
        
        pairs = {
            ")": "(",
            "]": "[",
            "}": "{",
        }
        stack = list()
        for ch in s:
            if ch in pairs:
                if not stack or stack[-1] != pairs[ch]:
                    return False
                stack.pop()
            else:
                stack.append(ch)
        
        return not stack

写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

相关推荐
Bucai_不才12 分钟前
【C++】初识C++之C语言加入光荣的进化(上)
c语言·c++·面向对象
木向14 分钟前
leetcode22:括号问题
开发语言·c++·leetcode
筑基.21 分钟前
basic_ios及其衍生库(附 GCC libstdc++源代码)
开发语言·c++
蹉跎x27 分钟前
力扣1358. 包含所有三种字符的子字符串数目
数据结构·算法·leetcode·职场和发展
yuyanjingtao34 分钟前
CCF-GESP 等级考试 2023年12月认证C++三级真题解析
c++·青少年编程·gesp·csp-j/s·编程等级考试
巫师不要去魔法部乱说2 小时前
PyCharm专项训练4 最小生成树算法
算法·pycharm
IT猿手2 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解GLSMOP1-GLSMOP9及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·算法·机器学习·matlab·强化学习
阿七想学习2 小时前
数据结构《排序》
java·数据结构·学习·算法·排序算法
王老师青少年编程2 小时前
gesp(二级)(12)洛谷:B3955:[GESP202403 二级] 小杨的日字矩阵
c++·算法·矩阵·gesp·csp·信奥赛
Kenneth風车3 小时前
【机器学习(九)】分类和回归任务-多层感知机(Multilayer Perceptron,MLP)算法-Sentosa_DSML社区版 (1)111
算法·机器学习·分类