STL應用——UVA673(堆棧)
阿新 • • 發佈:2017-08-10
pan mes div cout get() clas span sta 跪了
- 分析:棧的應用,遇到右括號便彈出棧頂元素,看是否與右括號相互匹配,其余情況壓入棧。
- 註意:本題有坑,空串空串,為此我跪了數次
#include<iostream> #include<string> #include<stack> using namespace std; int main() { int n; cin>>n; cin.get(); while(n--) { stack<char> s; string str; int flag=0; getline(cin,str); //按行讀入,可讀入空串 for(int i=0;i<str.size();i++) { if(str[i]==‘[‘||str[i]==‘(‘) s.push(str[i]); else if(!s.empty()&&s.top()==‘(‘&&str[i]==‘)‘) s.pop(); else if(!s.empty()&&s.top()==‘[‘&&str[i]==‘]‘) s.pop(); else flag=1; } if(!flag&&!s.size()) cout<<"Yes"<<endl; else cout<<"No"<<endl; } return 0; }
STL應用——UVA673(堆棧)