#include "bits/stdc++.h"
using namespace std; int comp(char s1,char s2){
if((s1 == '(' && s2 == ')') || (s1 == '['&&s2 == ']')) return ;
if((s1 == '(' && s2 == '(')||(s1 == '(' && s2 == '[')||(s1 == '[' && s2 == '(')||(s1 == '[' && s2 == '[')) return ;
} int main()
{
int t;
cin >> t;
while(t--){
string s;
cin >> s;
stack<char> st;
int flag = ;
for(int i=;i < s.size();i++){
if(st.empty()){
if(s[i] == '('||s[i] == '[') st.push(s[i]);
else{
flag = ;break;
}
}
else{
if(comp(st.top(),s[i]) == ){
st.pop();
}
else{
st.push(s[i]);
}
}
}
if(!st.empty()||flag == ) cout << "No" << endl;
else cout << "Yes" << endl;
}
return ;
}
今天复习了数据结构,突然想重写这个问题,只写了10分钟吧,就AC了,记得第一次写的时候写了两个小时,代码又臭又长,有时候代码能力就是这么不知不觉的增长。。。
分两种情况:1.栈空 2 栈非空
最后判断是否break出来的或者栈中有残余