20. 有效的括号
难度简单2174
给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。
有效字符串需满足:
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
示例 1:
输入:s = "()" 输出:true
示例 2:
输入:s = "()[]{}"
输出:true
示例 3:
输入:s = "(]" 输出:false
示例 4:
输入:s = "([)]" 输出:false
示例 5:
输入:s = "{[]}"
输出:true提示:
1 <= s.length <= 104s仅由括号'()[]{}'组成
题目讲解:
1.看懂题目,题目要求
- 左括号必须用相同类型的右括号闭合。
- 左括号必须以正确的顺序闭合。
换句话说就是左右两个括号要匹配,且不能出现 ([)] 这种中间夹着其他单个括号的情况
2.求解思路,利用栈的先进后出的思想下手。
①遍历整个字符串s,创建一个栈。当遇到左边的括号( { [ 时,依次将他们相匹配的) } ]放入栈中


②如果在遍历的过程中栈中已经无字符,即栈为空的情况,证明接下来字符串里的字符无法得到匹配,返回false。当遍历到右边字符时,弹出栈顶元素,判断是否与之相等(也就是相同),如果是则接着遍历字符串,不是则直接返回false。
因为左右字符要相匹配,如果不相等,则证明他们不匹配。
栈为空和判断是否匹配的情况可写在一起

③遍历完字符串后,若是栈中还有字符,证明有字符无法得到匹配,返回false,若是无字符,返回true。
![]()
代码如下
public boolean isVaild(String s) {
LinkedList<Character> stack = new LinkedList<>();
for (char c : s.toCharArray()) {
if (c == '(') {
stack.push(')');
} else if (c == '{') {
stack.push('}');
} else if (c == '[') {
stack.push(']');
} else if (stack.isEmpty() || c != stack.pop() ) {
return false;
}
}
return stack.isEmpty();
}第一次写关于算法题的文章,有什么讲的不好的地方,大家多多指教。
版权声明:本文为solar_xie原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。