题目
给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
- 每个右括号都有一个对应的相同类型的左括号。
示例
示例 1:
输入:s = “()”
输出:true
示例 2:
输入:s = “()[]{}”
输出:true
示例 3:
输入:s = “(]”
输出:false
提示
- 1 <= s.length <= 104
- s 仅由括号 ‘() [] {}’ 组成
题解
看到括号之间的匹配我们能想到什么?我们可以联想到栈的操作,先进后出,我们把左括号入栈,当匹配到相应的右括号后,再让对应的左括号出栈。
当字符串 s 长度为 0 的时候,我们直接返回true。
当字符串长度大于 0,并且字符串中的第一个字符为一个右括号时,我们直接返回 false,因为他匹配不到左括号。
我们可以采用Map集合创建一个左括号和右括号对应的键值对。这里采用的是双括号代码块初始化(不建议在项目实战中用)。
Map<Character, Character> map = new HashMap<>(){{
put('{', '}');
put('(', ')');
put('[', ']');
}};
我们最后返回栈 stack 是否为空,当栈最后为空的时候,那么是有效的括号,反之则不是。
代码
class Solution {
public boolean isValid(String s) {
Stack<Character> stack = new Stack<>();
Map<Character, Character> map = new HashMap<>(){{
put('{', '}');
put('(', ')');
put('[', ']');
}};
if(s.length() == 0) {
return true;
}
if(s.length() > 0 && !map.containsKey(s.charAt(0))) {
return false;
}
for(Character c : s.toCharArray()) {
if(map.containsKey(c)) {
stack.push(c);
}else if (stack.empty() || map.get(stack.pop()) != c) {
return false;
}
}
return stack.empty();
}
}