表达式求值 noip2013普及组t2
来源:互联网 发布:商标设计软件生成器 编辑:程序博客网 时间:2024/05/21 17:10
3292 表达式求值
2013年NOIP全国联赛普及组
给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。
输入仅有一行,为需要你计算的表达式,表达式中只包含数字、加法运算符“+”和乘法运算符“*”,且没有括号,所有参与运算的数字均为0到2^31-1之间的整数。输入数据保证这一行只有0~9、+、*这12种字符。
输出只有一行,包含一个整数,表示这个表达式的值。注意:当答案长度多于4位时,请只输出最后4位,前导0不输出。
[Sample 1]
1+1*3+4
[Sample 2]
1+1234567890*1
[Sample 3]
1+1000000003*1
[Sample 1]
8
[Sample 2]
7891
[Sample 3]
4
【样例说明】
样例1计算的结果为8,直接输出8。
样例2计算的结果为1234567891,输出后4位,即7891。
样例3计算的结果为1000000004,输出后4位,即4。
【数据范围】
对于30%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100;
对于80%的数据,0≤表达式中加法运算符和乘法运算符的总数≤1000;
对于100%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100000。
这是一道水水的题,纪念一下今天学的栈仅此而已。对了这读入卡了我一个小时。郁闷原来char一个变量等于 '\n' 就行了 。
#include <cstdio>
#include <stack>
using namespace std;
const int mod=10000;
stack<int> s;
char a;
int ans,num1,num2;
int main()
{
scanf("%d",&num1);
s.push(num1);
while(a!='\n')
{
scanf("%c",&a);
if(a!='\n')
{
scanf("%d",&num2);
s.push(num2);
}
if(a=='*')
{
int x=s.top();
s.pop();
int y=s.top();
s.pop();
s.push(x*y%mod);
}
}
while(!s.empty())
{
int x=s.top();
s.pop();
ans+=x;
ans%=mod;
}
printf("%d",ans);
return 0;
}
- NOIP2013普及组 T2 表达式求值
- NOIP2013普及组 T2 表达式求值
- 表达式求值 noip2013普及组t2
- 1180: [NOIP2013普及组]表达式求值
- [NOIP2013]表达式求值 T2 模拟
- [NOIP2013]表达式求值 T2 题解
- 【NOIP2013普及组P2】表达式求值(NKOJ2500)题解
- NOIP2013 表达式求值
- noip2013题解 普及组
- NOIP2013普及组 题解
- NOIP2013普及组 -SilverN
- noip2013普及组解题报告
- NOIP2013 普及组 车站分级
- NOIP2013普及组-车站分级
- noip2013 表达式求值 (表达式求值加法与乘法)
- |Tyvj|NOIP2013|模拟|P2772 表达式求值
- NOIP 2002普及组 T2
- NOIP2017普及组T2题解
- React之组件性能调优
- 网易笔试题:回文序列
- 自己动手撸个模板引擎(50行左右)
- Linxu - C进程间通信(预习内容九)
- 最大权闭合子图
- 表达式求值 noip2013普及组t2
- 排序二叉树添加删除java实现
- Reverse Words in a String
- Qt5编程——excel操作
- Remove Linked List Elements
- 【留言板】Hello
- Java-----集合类
- POJ 1201 Intervals(差分约束系统)
- 25属性动画