原题出处:https://leetcode.cn/leetbook/read/top-interview-questions-easy/xnbcaj/
解法一:
class Solution {
public boolean isValid(String s) {
Stack<Character> stack = new Stack();
char[] chars = s.toCharArray();
for (char c : chars) {
if ('{' == c) {
stack.push('}');
} else if ('[' == c) {
stack.push(']');
} else if ('(' == c) {
stack.push(')');
} else if (stack.isEmpty() || stack.pop() != c) {
return false;
}
}
return stack.isEmpty();
}
}
思路:利用栈的“先进后出”的特性进行校验。
如果每一个括号都是有效的那么,每一个左括号都会对应一个右括号。
要判断括号的有效性,左括号必须和右括号相对应。如果是有效括号,并且他们中间还有括号,那么他们必须也是有效的,所以最简单的一种方式就是使用栈来解决。
我们遍历字符串中的所有字符
1,如果遇到了左括号,就把对应的右括号压栈(比如遇到了字符'(',就把字符')'压栈)。
2,如果遇到了右括号
1)查看栈是否为空,如果为空,说明不能构成有效的括号,直接返回false。
2)如果栈不为空,栈顶元素出栈,然后判断出栈的这个元素是否等于这个右括号,如果不等于,说明不匹配,直接返回false。如果匹配,就继续判断字符串的下一个字符。
3,最后如果栈为空,说明是完全匹配,是有效的括号,否则如果栈不为空,说明不完全匹配,不是有效的括号。