题目链接:https://vjudge.net/contest/171027#problem/E

Yes的输出条件:

1. 空字符串

2.形如()[];

3.形如([])或者[()]

分析:

1.设置一个变量flag,初始值为1 (注意初始化的位置);

2.括号的左半边入栈;

3.若发现括号右半边的时候判断栈顶是否是对应的左半边(是:删除栈顶元素,否:flag=1,不是平衡的括号)!!!在进行这项判断之前一定要判断栈是不是空的,否则会出现错误,任何与栈有关的删除都是;

4.最后还要判断栈是不是空的,不然向((())这样的字符串也会输出“Yes”;

AC代码:

#include<iostream>
#include<cstdio>
#include<string>
#include<stack>
using namespace std;
int main()
{
string a;
int n,flag;
cin>>n;
getchar();
while (n--)
{
flag=;
stack<char>s;
getline(cin,a);
for (int i=;i<a.size();i++)
{
if (a[i]=='('||a[i]=='[')
s.push(a[i]);
else if (a[i]==')')
{
if (!s.empty())
{
if (s.top()=='(')
s.pop();
else
flag=;
}
else
flag=; }
else if (a[i]==']')
{
if (!s.empty())
{
if (s.top()=='[')
s.pop();
else
flag=;
}
else
flag=; }
}
if (!s.empty())
flag=;
if (flag==)
cout << "No" << endl;
else
cout << "Yes" << endl;
}
return ;
}

最新文章

  1. Android属性动画
  2. everything + autohotkey的配合使用
  3. 详解Linux目录(目录树详细解释)
  4. Python基本运算符
  5. hivepython 同时读入python 且python脚本中处理外部文件txt
  6. 如何写一个c++插件化系统
  7. Spring中PropertyPlaceholderConfigurer的使用
  8. 谷歌浏览器如何设置可以解决Ajax跨域问题?
  9. Pull解析-解析xml文件
  10. docker 通过commit方法创建镜像(Tomcat+Java+Scala)
  11. C#学习笔记11:C#中的顺序结构、分支结构、循环结构
  12. java代码转换为c# 工具
  13. 2 - SQL Server 2008 之 使用SQL语句为现有表添加约束条件
  14. Content Provider Basics ——Content Provider基础
  15. pyrailgun 0.24 : Python Package Index
  16. dedecms的入门使用
  17. Hibernate学习笔记①
  18. Jmeter元件运行顺序
  19. 在Node.js中使用ffi调用dll
  20. SSM获取表单数据插入数据库并返回插入记录的ID值

热门文章

  1. Comet OJ - Contest #3 D可爱的菜菜子(线段树+线性基的合并)
  2. Python笔记_第三篇_面向对象_3.重载(overloading)和重写(overriding)
  3. day51-线程-条件
  4. 892A. Greed#贪婪(优先队列priority_queue)
  5. 【网络流+贪心】Homework
  6. Matlab高级教程_第二篇:关于MATLAB转C#过程中遇到输出两组参数的问题
  7. HttpClient怎么获取cookie
  8. 1)关于配置centos的网络问题
  9. yum pip
  10. Estimating Gene Frequencies| method of maximum likelihood|point estimate