题目信息:
http://acm.nyist.net/JudgeOnline/problem.php?
pid=128
+ 2 * + 3 4 5的值就是 37,详见输入输出。
- 输入
- 有多组測试数据,每组測试数据占一行,随意两个操作符之间。随意两个操作数之间,操作数与操作符之间都有一个空格。输入的两个操作数可能是小数,数据保证输入的数都是正数。而且都小于10,操作数数目不超过500。
以EOF为输入结束的标志。 - 输出
- 对每组数据,输出该前缀表达式的值。
输出结果保留两位小数。
- 例子输入
-
+ 2 * + 3 4 5 + 5.1 / 3 7
- 例子输出
-
37.00 5.53
题目分析:
用两个栈进行存下数字和操作,进行计算,我刚開始想的是,每当连续输入两个数即可进行计算,并将结果压入数字栈中,而且操作时。应该保证后出栈的数字在前。先出栈的在后,这样能够保证-、/的结果。
。。。。哎。不知道为什么一直Wa,最后看看别人打代码。这题能够从后往前计算。遇到操作符进行计算即可。此题须要注意就是字符串到数字的转换。
AC代码:
#include<iostream> #include<cstdio> #include<map> #include<cstring> #include<string> #include<algorithm> #include<queue> #include<vector> #include<stack> #include<cstdlib> #include<cctype> #include<cstring> #include<cmath> using namespace std; char str[1005]; stack<double> dt; int start; void vol(){ int i=0,k=0; char a[15],b[15]; for(;str[start]!=' ';start--){ a[k++]=str[start]; } start--;//去掉数字后面的空格 a[k]='