给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: "()"
输出: true
示例 2:输入: "()[]{}"
输出: true
示例 3:输入: "(]"
输出: false
示例 4:输入: "([)]"
输出: false
解题思路:用栈来检验括号,这应该是我们学习栈的时候必学的一道例题了吧,比较简单,依次将字符串入栈或出栈操作,当字符是左括号的时候 ,入栈,当字符是右括号的时候,弹出栈顶元素检查是否匹配,若不匹配,直接返回false。当字符串遍历结束后,检查栈中是否还有剩余元素,若有,返回false,若无,返回true。
class Solution {
private Stack<Character> stack = new Stack<>();
public boolean isValid(String s) {
for(char c : s.toCharArray()){
if(c == '(' || c == '{' || c == '['){
stack.push(c);
}else{
if(stack.isEmpty()) return false;
char tmp = stack.pop();
boolean b1 = c == ')' && tmp != '(';
boolean b2 = c == '}' && tmp != '{';
boolean b3 = c == ']' && tmp != '[';
if(b1 || b2 || b3){
return false;
}
}
}
if(stack.isEmpty()){
return true;
}
return false;
}
}