leetcode每日一题之有效的括号
**题目链接:**https://leetcode-cn.com/problems/valid-parentheses/
题目描述:
给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
示例 1:
输入:s = "()"
输出:true
示例 2:
输入:s = "()[]{}"
输出:true
示例 3:
输入:s = "(]"
输出:false
示例 4:
输入:s = "([)]"
输出:false
示例 5:
输入:s = "{[]}"
输出:true
**解法:**用栈的思路,将( [ { 入栈,然后进行匹配
代码如下:
//(())[] (())[]( (())[])
public boolean isValid(String s) {
if (s.length() == 0) return true;
Stack<Character> stack = new Stack<>();
char[] charArray = s.toCharArray();
for (int i = 0; i < charArray.length; i++) {//遍历栈
char c = charArray[i];//转化为字符数组
if (c == '(' || c == '[' || c == '{') {
stack.push(c);//( [ { 入栈
} else { //对应 ) ] } 这三种情况
if (stack.isEmpty()) return false;//(())[])对应这种情况
char temp = stack.pop();//栈顶元素出栈
if (c == ')') {
if (temp != '(') return false;//将栈顶元素和没有入栈的元素比较,就是比如(())[],((肯定入栈,然后拿着栈顶的(和没有入栈的)匹配
} else if (c == ']') {
if (temp != '[') return false;
} else if (c == '}') {
if (temp != '{') return false;
}
}
}
//最后栈中元素如果是空,就可以匹配返回true
return stack.isEmpty() ? true : false;
}
在评论区中发现比较巧妙的解法:
public boolean isValid(String s) {
while (s.contains("()") || s.contains("[]") || s.contains("{}")) {
if (s.contains("()")) {
s = s.replace("()", "");
}
if (s.contains("{}")) {
s = s.replace("{}", "");
}
if (s.contains("[]")) {
s = s.replace("[]", "");
}
}
return s.length() == 0;
}
配套视频讲解资料:
https://www.youtube.com/watch?v=Gv_RrM6nqsU&list=PLVCBLinWsHYyYvQlZNAAy81s9z_OezZvl&index=22