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

F - 简单计算器

时间:2016-07-16 19:21:59      阅读:169      评论:0      收藏:0      [点我收藏+]

标签:

F - 简单计算器

Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u

Description

读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。 
 

Input

测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。 
 

Output

对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。 
 

Sample Input

1 + 2 4 + 2 * 5 - 7 / 11 0
 

Sample Output

3.00 13.36
 
 
 
技术分享
 1 #include <iostream>
 2 #include <stack>
 3 #include <stdio.h>
 4 using namespace std;
 5 
 6 int main()
 7 {
 8     double num1;
 9     char ch;
10     while (cin>>num1)
11     {
12         stack<double> data;
13         ch=getchar();
14         if (num1==0&&ch==\n)
15         {
16             break;
17         }//结束
18 
19         double num2;
20         while (cin>>ch)
21         {
22             if (ch==+||ch==-)
23             {
24                 cin>>num2;
25                 if (ch==-) num2=-num2;
26                 data.push(num1);
27                 num1=num2;
28                 ch=getchar();
29                 if (ch==\n)
30                 {
31                     data.push(num1);
32                     break;
33                 }
34             }
35             if (ch==*||ch==/)
36             {
37                 cin>>num2;
38                 if(ch==*)
39                 {
40                     num1*=num2;
41                     ch=getchar();
42                     if (ch==\n)
43                     {
44                         data.push(num1);
45                         break;
46                     }
47                 }
48                 if (ch==/)
49                 {
50                     num1/=num2;
51                     ch=getchar();
52                     if (ch==\n)
53                     {
54                         data.push(num1);
55                         break;
56                     }
57                 }        
58             }
59         }
60         double ans=0;
61         while (!data.empty())
62         {
63             ans+=data.top();
64             data.pop();
65         }
66         printf("%.2lf\n",ans);
67     }
68     return 0;
69 }
View Code

 

F - 简单计算器

标签:

原文地址:http://www.cnblogs.com/haoabcd2010/p/5676718.html

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