给定仅包含“()[]{}”六种括号的字符串,请你判断该字符串中,括号的匹配是否是合法的,也就是对应括号的数量、嵌套顺序完全正确。
输入格式:
第一行一个整数T(T<=10)
其后T行每行一个字符串只包含[{()}]六种字符(字符串长度2e5以内)
输出格式:
对于每个字符串,匹配输出Yes,否则输出No
输入样例:
2
{()[]}
([)]
输出样例:
Yes
No
分析:符号匹配问题是栈的一个重要应用,诸如求解表达式的值,逆波兰算法,中缀后缀表达式的转换,都可以用栈解决,用测试的例子来进行说明:{()[]},遇到 {,将其入栈,遇到 (,也入栈,遇到),此时栈内元素是 {( ,取出栈顶元素,此时栈顶元素是 (,发现 ( 和 ) 是匹配的,继续判断,遇到 [ ,将其入栈,遇到 ] ,取出栈顶元素,发现是 [ ,匹配,继续判断,遇到 } ,取出栈顶元素,发现是 { ,匹配,此时已经到达字符串结尾,且此时栈空,说明每一个都匹配成功,输入Yes。([)]:遇到 ( ,将其入栈,遇到 [ ,将其入栈,此时栈内元素是 ( [ ,遇到 ) ,取出栈顶元素,发现是 [ ,不匹配,则不用再判断,直接输入No,即可。
这里附上LeetCode中的一道题,也是与栈相关的表达式求解问题,之前做的。。逆波兰表达式求值-力扣(LeetCode)
#include <iostream>
#include <stack>
#include <algorithm>
#include <string>
using namespace std;
bool istrue(string s) {
stack<char> st;
for(int i = 0;i<s.length();i++){
char t = s[i];
if(t=='('||t=='['||t=='{')
st.push(t);
else{
if(st.empty())
return false;
char tp = st.top();
st.pop();
if(t==')'&&tp!='(')
return false;
if(t==']'&&tp!='[')
return false;
if(t=='}'&&tp!='{')
return false;
}
}
return st.empty();
}
int main() {
int n;
cin >> n;
string str;
for(int i = 0; i<n; i++) {
cin >> str;
if(istrue(str))
cout << "Yes" << endl;
else
cout << "No" << endl;
}
return 0;
}