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

文章目录

  • Tag
  • 题目来源
  • 题目解读
  • 解题思路
    • 方法一:栈+哈希表
  • 其他语言
    • c
    • python3
  • 写在最后

Tag

【栈】


题目来源

20. 有效的括号

【面试经典150 | 栈】有效的括号_第1张图片

题目解读

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

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


解题思路

方法一:栈+哈希表

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

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

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

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

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

实现代码

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

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

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

写在最后

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

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

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

你可能感兴趣的:(面试经典150题,栈,C++,算法)