NY : 括号匹配问题
3[(])(])([[]()])
NoNoYes
naonao
STL :
栈(statck)这种数据结构在计算机中是相当出名的。栈中的数据是先进后出的(First In Last Out, FILO)。栈只有一个出口,允许新增元素(只能在栈顶上增加)、移出元素(只能移出栈顶元素)、取得栈顶元素等操作。在STL中,栈是以别的容器作为底部结构,再将接口改变,使之符合栈的特性就可以了。因此实现非常的方便。下面就给出栈的函数列表和VS2008中栈的源代码,在STL中栈一共就5个常用操作函数(top()、push()、pop()、 size()、empty() ),很好记的。

思想:利用STL中的栈(STACK),将左括号放入栈中,遇到右括号,①判断栈是否为空,空则直接判断整个字符串括号不匹配。不为空进行②。
②判断该右括号是否与栈顶元素匹配,匹配则将栈顶元素退栈,不匹配则直接判断整个字符串括号不匹配。
代码:
#include <iostream>#include <stack>#include <cstdio>#include <cstring>using namespace std;int main(){ int n; char str[10010]; cin>>n; while(n--) { cin>>str; int len=strlen(str); int i; stack <char> c; for(i=0;i<len;++i) { if(str[i]=='(' || str[i]=='[') { c.push(str[i]); } if(str[i]==')') { char ch; if(c.empty()) break; else { ch=c.top(); c.pop(); } if(ch!='(') { break; } } if(str[i]==']') { char ch; if(c.empty()) break; else { ch=c.top(); c.pop(); } if(ch!='[') { break; } } } if(i>=len) { cout<<"Yes"<<endl; } else { cout<<"No"<<endl; } } return 0;}