1.题目
给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。
2.代码
class Solution {标签:false,有效,else,括号,字符串,push,LeetCode.20,stack From: https://blog.51cto.com/u_15806469/6031773
public boolean isValid(String s) {
//用栈来模拟,注意类型是Character
Stack<Character> stack = new Stack<>();
for(int i=0; i<s.length(); i++){
//遍历字符串,获得每一个字符
char c = s.charAt(i);
//把获得的每一个左括号的右括号放到栈中
if(c == '('){
stack.push(')');
}else if(c=='{'){
stack.push('}');
}else if(c=='['){
stack.push(']');
}else if(stack.empty() || c!=stack.peek()){
//当栈为空或者遍历到的右括号和栈顶的元素不符合时,就返回false
return false;
}else{//这里剩下的情况,就是遍历到右括号时,再消掉对应的栈顶
stack.pop();
}
}
//最后看看栈是不是为空,是返回true,不是就返回false
return stack.empty();
}
}