[NOIP2013]表达式求值 T2 模拟
来源:互联网 发布:ios与安卓的区别 知乎 编辑:程序博客网 时间:2024/05/22 05:25
Description
给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。
Input
输入仅有一行,为需要你计算的表达式,表达式中只包含数字、加法运算符“+”和乘法运算符“*”,且没有括号,所有参与运算的数字均为0到2^31-1之间的整数。输入数据保证这一行只有0~9、+、*这12种字符。
Output
输出只有一行,包含一个整数,表示这个表达式的值。注意:当答案长度多于4位时,请只输出最后4位,前导0不输出。
Sample Input
Sample Input I:1+1*3+4Sample Input II:1+1234567890*1Sample Input III:1+1000000003*1
Sample Output
Sample Output I:8Sample Output II:7891Sample Output III:4
HINT
【样例说明】
样例1计算的结果为8,直接输出8。
样例2计算的结果为1234567891,输出后4位,即7891。
样例3计算的结果为1000000004,输出后4位,即4。
【数据范围】
对于30%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100;
对于80%的数据,0≤表达式中加法运算符和乘法运算符的总数≤1000;
对于100%的数据,0≤表达式中加法运算符和乘法运算符的总数≤100000。
#include<stdio.h>long long a[1000001];char c[1000001];int idx=2,ans;int main(){ scanf("%d",&a[1]); while(scanf("%c",&c[idx++])!=EOF) scanf("%d",&a[idx++]); idx-=2; for(int i=idx;i>0;i--) if(c[i]=='*') a[i-1]=(a[i-1]*a[i+1])%10000; for(int i=1;i<=idx;i++) if(c[i]=='+') ans=(ans+a[i+1])%10000; printf("%d",(ans+a[1])%10000);}
阅读全文
2 0
- [NOIP2013]表达式求值 T2 模拟
- [NOIP2013]表达式求值 T2 题解
- NOIP2013普及组 T2 表达式求值
- NOIP2013普及组 T2 表达式求值
- 表达式求值 noip2013普及组t2
- |Tyvj|NOIP2013|模拟|P2772 表达式求值
- NOIP2013 表达式求值
- noip2013 表达式求值 (表达式求值加法与乘法)
- 1180: [NOIP2013普及组]表达式求值
- 栈模拟表达式求值
- 【NOIP2013普及组P2】表达式求值(NKOJ2500)题解
- NYOJ 305-表达式求值【模拟】
- nyoj1272~表达式求值(stack+模拟)
- NOIP2013 D1 T2 国王游戏
- NYOJ-305 表达式求值(模拟)
- 表达式求值——栈模拟
- nyoj 35 表达式求值<模拟+栈>
- Problem B: [NOIP2013]花匠 D2 T2
- 快速幂
- codeforce_868B_模拟水
- ZigZag Conversion:把字符串改写成Z字排列
- 延迟hover事件
- bzoj1774 USACO 2009 Dec Gold 2.Cow Toll Paths 过路费 翻译+题解
- [NOIP2013]表达式求值 T2 模拟
- Oracle中分号提示无效字符的问题
- windows下matplotlib图例中文无法显示的解决办法
- Java 创建对象的几种方法
- Kubernetes安装和使用
- 新生代和老年代区别
- Geometric.NestingWorks.2017.SP1.0.Win64 1CD
- 用Eclipse Memory Analyzer查找内存泄露
- CS231n学习笔记--9.CNN Architectures