码迷,mamicode.com
首页 > 其他好文 > 详细

刷过一题之NOIP2013表达式求值

时间:2016-01-24 14:18:37      阅读:337      评论:0      收藏:0      [点我收藏+]

标签:

给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值。

 

输入:

仅有一行,为需要你计算的表达式,表达式中只包含数字、加法运算符“+”和乘法运算符“*”,且没有括号,所有参与运算的数字均为0到2^31-1之间的整数。输入数据保证这一行只有0到9、+、*这12种字符。

 

输出:

输出只有一行,包含一个整数,表示这个表达式的值。注意:当答案长度多于4位时,请只输出最后4位,前导0不输出.

 

输入示例:

1+1*3+4

 

输出示例:

8

 

数据范围:0≤表达式中加法运算符和乘法运算符的总数≤100000。

 

没得可说,简单模拟。

技术分享
 1 #include<iostream>
 2 using namespace std;
 3 int a[100001];
 4 int main()
 5 {
 6 
 7     int x,ans=1,n,m,p=0;
 8     char c;
 9     cin>>a[1];//为了便于计算,我们先把第一个字符(有可能是数字)输入 
10     while(scanf("%c",&c)!=EOF)//输入表达式符号 
11     {
12         if(c==\n) break;//如果输入换行符,那么预示着表达式输入完毕 
13         scanf("%d",&x);//输入表达式中的数字 
14         x=x%10000;//取模 
15         if(c==+) a[++ans]=x;//计算加法的情况 
16         else//计算乘法的情况 
17         {
18             n=a[ans];
19             a[ans]=(n*x)%10000;//取模 
20         }
21     }
22     for(int i=1;i<=ans;i++) p=p+a[i];//因为我们是分别储存的结果,所以要求累加和 
23     p=p%10000;//取模 
24     printf("%d\n",p);
25     //system("pausE");
26     return 0;
27 }
C++ answer

 

刷过一题之NOIP2013表达式求值

标签:

原文地址:http://www.cnblogs.com/nightfury/p/5155020.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!