刷过一题之NOIP2013表达式求值

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了刷过一题之NOIP2013表达式求值相关的知识,希望对你有一定的参考价值。

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

 

输入:

仅有一行,为需要你计算的表达式,表达式中只包含数字、加法运算符“+”和乘法运算符“*”,且没有括号,所有参与运算的数字均为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表达式求值的主要内容,如果未能解决你的问题,请参考以下文章

刷过一题之NOIP2013转圈游戏

刷过一题之NOIP2012寻宝

刷过一题之NOIP2007守望者的逃离

刷过一题之区间最小值

刷过一题之矩阵最小值

表达式求值(NOIP2013 普及组第二题)