Parentheses Balance (括号平衡)---栈
2024-08-30 18:23:33
题目链接: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 ;
}
最新文章
- Android属性动画
- everything + autohotkey的配合使用
- 详解Linux目录(目录树详细解释)
- Python基本运算符
- hivepython 同时读入python 且python脚本中处理外部文件txt
- 如何写一个c++插件化系统
- Spring中PropertyPlaceholderConfigurer的使用
- 谷歌浏览器如何设置可以解决Ajax跨域问题?
- Pull解析-解析xml文件
- docker 通过commit方法创建镜像(Tomcat+Java+Scala)
- C#学习笔记11:C#中的顺序结构、分支结构、循环结构
- java代码转换为c# 工具
- 2 - SQL Server 2008 之 使用SQL语句为现有表添加约束条件
- Content Provider Basics ——Content Provider基础
- pyrailgun 0.24 : Python Package Index
- dedecms的入门使用
- Hibernate学习笔记①
- Jmeter元件运行顺序
- 在Node.js中使用ffi调用dll
- SSM获取表单数据插入数据库并返回插入记录的ID值
热门文章
- Comet OJ - Contest #3 D可爱的菜菜子(线段树+线性基的合并)
- Python笔记_第三篇_面向对象_3.重载(overloading)和重写(overriding)
- day51-线程-条件
- 892A. Greed#贪婪(优先队列priority_queue)
- 【网络流+贪心】Homework
- Matlab高级教程_第二篇:关于MATLAB转C#过程中遇到输出两组参数的问题
- HttpClient怎么获取cookie
- 1)关于配置centos的网络问题
- yum pip
- Estimating Gene Frequencies| method of maximum likelihood|point estimate