1. 程式人生 > >STL應用——UVA673(堆棧)

STL應用——UVA673(堆棧)

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(堆棧)