链接:https://leetcode.cn/problems/valid-parentheses/solution/by-xun-ge-v-f8h8/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
题目![](https://img-blog.csdnimg.cn/466f2cabc62f42ca8ed3126318d079b7.png)
示例![](https://img-blog.csdnimg.cn/a4c1e6c47500463882ba187434988056.png)
思路
解题思路
由于栈结构的特殊性,非常适合做对称匹配类的题目。
首先要弄清楚,字符串里的括号不匹配有几种情况:
- 第一种情况,字符串里左方向的括号多余了 ,所以不匹配。
- 第二种情况,括号没有多余,但是 括号的类型没有匹配上。
- 第三种情况,字符串里右方向的括号多余了,所以不匹配。
我们的代码只要覆盖了这三种不匹配的情况,就不会出问题。
- 第一种情况:已经遍历完了字符串,但是栈不为空,说明有相应的左括号没有右括号来匹配,所以return false
- 第二种情况:遍历字符串匹配的过程中,发现栈里没有要匹配的字符。所以return false
- 第三种情况:遍历字符串匹配的过程中,栈已经为空了,没有匹配的字符了,说明右括号没有找到对应的左括号return false
那么什么时候说明左括号和右括号全都匹配了呢,就是字符串遍历完之后,栈是空的,就说明全都匹配了。
分析完之后,代码其实就比较好写了,
但还有一些技巧,在匹配左括号的时候,右括号先入栈,就只需要比较当前元素和栈顶相不相等就可以了,比左括号先入栈代码实现要简单的多了!
代码
char pairs(char a) {//将字符进行简单转换,方便后面比较判断
if (a == '}') return '{';
if (a == ']') return '[';
if (a == ')') return '(';
return 0;
}
bool isValid(char* s) {
int n = strlen(s);
if (n % 2 == 1) {//如果长度为奇数,肯定会存在一个不匹配,提前结束
return false;
}
int stk[n + 1], top = 0;//初始化变量
for (int i = 0; i < n; i++) {//遍历字符串每一个元素
char ch = pairs(s[i]);//简单处理
if (ch) {//出栈
if (top == 0 || stk[top - 1] != ch) {//栈顶元素匹配不成功,返回false,不能匹配
return false;
}
top--;//匹配成功,将栈顶元素弹出
} else {//入栈
stk[top++] = s[i];
}
}
return top == 0;//栈中无任何元素,说明全部匹配成功
}
作者:xun-ge-v
链接:https://leetcode.cn/problems/valid-parentheses/solution/by-xun-ge-v-f8h8/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。