一、题目
给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
示例 1:
输入:s = “()”
输出:true
示例 2:
输入:s = “()[]{}”
输出:true
示例 3:
输入:s = “(]”
输出:false
示例 4:
输入:s = “([)]”
输出:false
示例 5:
输入:s = “{[]}”
输出:true
提示:
1 <= s.length <= 104
s 仅由括号 ‘()[]{}’ 组成
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/valid-parentheses
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
二、代码实现
用了两个栈,一个栈区去实现入,一个栈实现出
代码优化
n%2!=0时,肯定返回false
class Solution {
public boolean isValid(String s) {
Stack<Character> stack1 = new Stack<Character>();
Stack<Character> stack2 = new Stack<Character>();
char[] c = s.toCharArray();
for (int i = 0; i < c.length; i++) {
stack1.push(c[i]);
}
while (!stack1.empty()) {
char temp = stack1.pop();
if (isRight(temp))
stack2.push(temp);
else if (stack2.isEmpty() || !isMatch(temp, stack2.pop())) {
return false;
}
}
if (!stack2.isEmpty())
return false;
return true;
}
private static boolean isMatch(char temp, Character temp2) {
// TODO Auto-generated method stub
return (temp == '{' && temp2 == '}') || (temp == '[' && temp2 == ']') || (temp == '(' && temp2 == ')');
}
private static boolean isRight(char temp) {
// TODO Auto-generated method stub
return (temp == ']' || temp == '}' || temp == ')');
}
}
该博客讨论了如何编写一个算法来判断给定的括号字符串是否有效,即括号是否正确匹配和顺序。通过使用两个栈,一个用于存储左括号,另一个用于检查右括号的匹配,代码实现了有效括号的验证。当遇到右括号时,会检查它与栈顶的左括号是否匹配,如果不匹配或栈为空,则返回false。最后,如果栈为空且所有括号都已匹配,则返回true。

被折叠的 条评论
为什么被折叠?



