文章目录
- Tag
- 题目来源
- 题目解读
- 解题思路
- 方法一:栈+哈希表
- 其他语言
- c
- python3
- 写在最后
Tag
【栈】
题目来源
20. 有效的括号
题目解读
括号有三种类型,分别是小括号、中括号和大括号,每种括号的左右两半括号必须一一对应才是有效的括号,如果某一种括号之间穿插者其他的闭合的括号,那么这个括号字符串也是有效的,比如 "({[]})"
就是一个有效的括号字符串。
现在给你一个仅有括号组成的字符串,判断该字符串是否是有效的字符串。
解题思路
方法一:栈+哈希表
本题使用栈来解决,我们可以边更新栈边在栈中找闭合的括号。
我们遍历字符串,如果栈为空,我们自然是要将当前的括号字符加入到栈中的,继续遍历字符串:
- 当遇到的括号是右括号时,我们希望可以找到一个相同类型的左括号,于是如果栈顶的括号是对应类型的左括号,那么我们就将栈顶匹配的左括号弹出站;如果栈顶的括号不是对应类型的左括号,则当前遍历的括号无法闭合,那么该符号字符串不是有效的字符串,直接返回
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 Falsepairs = {")": "(","]": "[","}": "{",}stack = list()for ch in s:if ch in pairs:if not stack or stack[-1] != pairs[ch]:return Falsestack.pop()else:stack.append(ch)return not stack
写在最后
如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。
如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。
最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。