当前位置:网站首页>一本通1353——表达式括号匹配(栈)
一本通1353——表达式括号匹配(栈)
2022-07-27 05:04:00 【竹林居士-】
题目网址
http://ybt.ssoier.cn:8088/problem_show.php?pid=1353
【题目描述】
假设一个表达式有英文字母(小写)、运算符(+,-,∗,/)和左右小(圆)括号构成,以“@”作为表达式的结束符。请编写一个程序检查表达式中的左右圆括号是否匹配,若匹配,则返回“YES”;否则返回“NO”。表达式长度小于255,左圆括号少于20个。
【输入】
一行数据,即表达式。
【输出】
一行,即“YES” 或“NO”。
【输入样例】
2*(x+y)/(1-x)@
【输出样例】
YES
【提示】
【样例输入2】
(25+x)*(a*(a+b+b)@
【样例输出2】
NO
审题
表达式没有空格,直接cin即可。数字,符号,字母均对题目没有影响
思路
1.循环轮流判断每一个字符
2.如果当前字符是@,退出循环
3.如果当前字符是左括号,入栈
4.如果是右括号,判断栈中有没有左括号。如果没有,说明没有左括号与其配对,输出NO;否则让一个左括号出栈,表示已被配对
for(int i=0;i<str.size();i++)
{
if(str[i]=='@') break;
if(str[i]=='(')stk.push(str[i]);
if(str[i]==')'){
if(stk.empty())
{
cout<<"NO";
return 0;
}
stk.pop();
}
}5.循环结束后判断栈是否为空。如果不为空,说明还有左括号还未匹配,输出NO,否则输出YES
if(stk.empty()) {
cout<<"YES";
}
else{
cout<<"NO";
return 0;
}完整代码
#include<bits/stdc++.h>
using namespace std;
string str;
stack<char>stk;
int main()
{
cin>>str;
for(int i=0;i<str.size();i++)
{
if(str[i]=='@') break;
if(str[i]=='(')stk.push(str[i]);
if(str[i]==')'){
if(stk.empty())
{
cout<<"NO";
return 0;
}
stk.pop();
}
}
if(stk.empty()) {
cout<<"YES";
}
else
cout<<"NO";
return 0;
}边栏推荐
猜你喜欢

2021 Niuke multi school training camp 5 (question b)

页面的配置

C语言初阶——分支语句(if,switch)

First acquaintance with C language - first acquaintance with pointer

C language elementary level -- branch statement (if, switch)

Looking at the PK of alphago and Li Shishi from a deep perspective

背景图片相关应用-铺满,自适应

node 安装调试

C WPF uses listbox to implement ruler control

Source code of document type full-text retrieval knowledge base management system
随机推荐
后台优惠券管理
Introduction and management of heap memory in C language
努力进化中_我的第一篇csdn博客
==,===,Object.is
How to get started quickly and strengthen learning?
My first blog
Flask请求数据获取与响应
Elment UI usage
GalleryCMS下载安装与配置
路由的配置和前往登录首页进行发送请求
页面的基本布局
JS中深拷贝和浅拷贝的区别
Js中如何进行隐式转换
维持登录,路由跳转
时间复杂度与空间复杂度
Promise的理解,以及它的实例方法
项目登录注册思路
set集合
Initial C language -- the function of keyword static
C语言函数入门介绍