leetCode-20-Valid Parentheses
题目描述(简单难度)
括号匹配问题。
如果只有一种括号,我们完全可以用一个计数器 count ,遍历整个字符串,遇到左括号加 1 ,遇到右括号减 1,遍历结束后,如果 count 等于 0 ,则表示全部匹配。但如果有多种括号,像 ( [ ) ] 这种情况它依旧会得到 0,所以我们需要用其他的方法。
栈!
遍历整个字符串,遇到左括号就入栈,然后遇到和栈顶对应的右括号就出栈,遍历结束后,如果栈为空,就表示全部匹配。
public boolean isValid(String s) {
Stack<Character> brackets = new Stack<Character>();
for(int i = 0;i < s.length();i++){
char c = s.charAt(i);
switch(c){
case '(':
case '[':
case '{':
brackets.push(c);
break;
case ')':
if(!brackets.empty()){
if(brackets.peek()== '('){
brackets.pop();
}else{
return false;
}
}else{
return false;
}
break;
case ']':
if(!brackets.empty()){
if(brackets.peek()=='['){
brackets.pop();
}else{
return false;
}
}else{
return false;
}
break;
case '}':
if(!brackets.empty()){
if(brackets.peek()=='{'){
brackets.pop();
}else{
return false;
}
}else{
return false;
}
}
}
return brackets.empty();
}
时间复杂度:O(n)。
空间复杂度:O(n)。
总
如果学过数据结构,一定写过计算器,括号匹配问题一定遇到过的。
作者:windliang
来源:https://windliang.cc
看完两件小事
如果你觉得这篇文章对你挺有启发,我想请你帮我两个小忙:
- 把这篇文章分享给你的朋友 / 交流群,让更多的人看到,一起进步,一起成长!
- 关注公众号 「方志朋」,公众号后台回复「666」 免费领取我精心整理的进阶资源教程
本文著作权归作者所有,如若转载,请注明出处
转载请注明:文章转载自「 Java极客技术学习 」https://www.javajike.com