首页 > 其他 > 详细

UVA 673 Parentheses Balance

时间:2015-10-15 14:12:22      阅读:141      评论:0      收藏:0      [点我收藏+]

 

题意:

  匹配括号,看是否所有括号都匹配。

分析:

  空行的时候要输出yes,其它的用栈正常做就行。

代码:

  

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
#include <stack>
using namespace std;
bool judge(char a,char b)
{
if(a==‘[‘&&b==‘]‘)return 1;
if(a==‘(‘&&b==‘)‘)return 1;
return 0;
}
bool left(char a)
{
if(a==‘[‘||a==‘(‘)return 1;
return 0;
}
int main()
{
int cas;
char s[200];
scanf("%d",&cas);
getchar();
while(cas--)
{
stack<char>q;
gets(s);//cout<<strlen(s);
if(strcmp(s,"\n")==0)
{
cout<<"YES"<<endl;
continue;
}
int i,j,k;
for(i=0;s[i];i++)
{
if(q.empty())
{
q.push(s[i]);
}
else if(!judge(q.top(),s[i]))
{
if(left(s[i]))
q.push(s[i]);
}
else q.pop();
}
if(q.empty())
cout<<"Yes"<<endl;
else
cout<<"No"<<endl;
}
}

UVA 673 Parentheses Balance

原文:http://www.cnblogs.com/137033036-wjl/p/4882069.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!