给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。
示例 1:
输入: “()”
输出: true
示例 2:
输入: “()[]{}”
输出: true
示例 3:
输入: “(]”
输出: false
示例 4:
输入: “([)]”
输出: false
示例 5:
输入: “{[]}”
输出: true
方法一:
Map.containsKey()方法该方法判断Map集合对象中是否包含指定的键名。如果Map集合中包含指定的键名,则返回true,否则返回false。
Map.get()方法——返回指定键所映射的值
if(!map.containsKey(chars[i])) {
stack.push(chars[i]);//为左括号时直接入栈
}
在理解这段的意思:假如 s="([)" ;
map.containsKey(chars[i])意思是map集合中包含指定的键名,
则返回true,否则返回false。第一次chars[i]='(',
则map.containsKey(chars[i])第一次返回false,
因为在map中存入的键是')',']','}',
所以!map.containsKey(chars[i])则为true,
所以这样才可以将左括号‘(’入栈。
class Solution {
public boolean isValid(String s) {
Stack<Character> stack=new Stack<Character>();
Map<Character, Character> map=new HashMap<>();
char[] chars=s.toCharArray();
map.put(')', '(');
map.put(']', '[');
map.put('}', '{');
for(int i=0;i<chars.length;i++) {
if(!map.containsKey(chars[i])) {
//为左括号时直接入栈
stack.push(chars[i]);
}else {
//为右括号时,如果栈为空或者栈顶与该括号类型不匹配返回false
if(stack.empty()||map.get(chars[i])!=stack.pop()) {
return false;
}
}
}
//字符串遍历完毕后,如果栈为空返回true,反之返回false
return stack.empty();
}
}
方法二:
思路:首先把字符串里面的左括号所对应的右括号进栈,当遇到不是左括号的时候,就判断这个括号是否和刚进栈的字符一样。
在查完之前,如果栈为空,说明这个字符之前的括号都是配对的,并且这个是右括号,返回false
例如:’([]){’ 前四个字符配对,第五个没有配对的,所以返回false.
class Solution {
public boolean isValid(String s) {
Stack<Character> stack=new Stack<Character>();
for(char ch:s.toCharArray()){
if(ch=='('){
stack.push(')');
}
else if(ch=='['){
stack.push(']');
}
else if(ch=='{'){
stack.push('}');
}
else{
if(stack.empty()||ch!=stack.pop()){
return false;
}
}
}
return stack.empty();
}
}