hdu - 1237 题解

Posted 远见望远

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hdu - 1237 题解相关的知识,希望对你有一定的参考价值。

题意:给出一个数字计算式,包含+,-,*,/四种符号,计算值

题解:最大坑点:不能仅仅判断第一个是0就结束计算,有可能有:0 + 1这样的情况

所以1.判断第一个是否是0,如果是,则判断下一个符号是否是‘\n‘

2.读入数字和运算符,如果是*,/,取出栈顶元素直接计算完成后压栈,如果是-,将数字相反数压栈,如果是+,将数字压栈。

3.计算栈内元素之和

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<algorithm>
 4 #include<stack>
 5 using namespace std;
 6 stack<double> st;
 7 int main()
 8 {
 9     int x;
10     while(true)
11     {
12         scanf("%d",&x);
13         char c;
14         c=getchar();
15         if(x==0&&c==\n)
16         {
17             break;
18         }
19         while(!st.empty())
20         {
21             st.pop();
22         }
23         st.push(x);
24         while(true)
25         {
26             if(c==\n)
27             {
28                 break;
29             }
30             while(c== )
31             {
32                 c=getchar();
33             }
34             scanf("%d",&x);
35             if(c==*)
36             {
37                 double tmp=st.top();
38                 st.pop();
39                 st.push(tmp*x);
40             }
41             if(c==/)
42             {
43                 double tmp=st.top();
44                 st.pop();
45                 st.push(tmp/x);
46             }
47             if(c==-)
48             {
49                 st.push(-x);
50             }
51             if(c==+)
52             {
53                 st.push(x);
54             }
55             c=getchar();
56         }
57         double res=0;
58         while(!st.empty())
59         {
60             res+=st.top();
61             st.pop();
62         }
63         printf("%.2lf\n",res);
64     }
65     return 0;
66 }

 

以上是关于hdu - 1237 题解的主要内容,如果未能解决你的问题,请参考以下文章

C - 简单计算器 (HDU - 1237)

HDU 1237 简单计算器

*HDU 1237 栈

Hdu 1237简单计算器

HDU 1237 简单计算器(后缀式+栈)

hdu 1237 简单计算器(栈处理)