首页 > 代码库 > 括号匹配(栈的应用)
括号匹配(栈的应用)
#include <iostream> #include <stack> #include <string> using namespace std; int main() { int n;cin>>n; while(n--){ stack<char> s; string str;cin>>str; for(int i=0;i!=str.length();i++){ if(s.empty()) s.push(str[i]); else{ if(s.top()==‘(‘){ if(str[i]==‘)‘) s.pop(); else s.push(str[i]);} else if(s.top()==‘[‘){ if(str[i]==‘]‘) s.pop(); else s.push(str[i]); } else {s.push(str[i]);} } } if(s.empty()) cout<<"Yes"<<endl; else cout<<"No"<<endl; } return 0; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。