3-07. 求前缀表达式的值(25) (ZJU_PAT数学)

题目链接:http://pat.zju.edu.cn/contests/ds/3-07

算术表达式有前缀表示法、中缀表示法和后缀表示法等形式。前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4。请设计程序计算前缀表达式的结果值。

输入格式说明:

输入在一行内给出不超过30个字符的前缀表达式,只包含+、-、*、\以及运算数,不同对象(运算数、运算符号)之间以空格分隔。

输出格式说明:

输出前缀表达式的运算结果,精确到小数点后1位,或错误信息“ERROR”。

样例输入与输出:

序号 输入 输出
1
+ + 2 * 3 - 7 4 / 8 4
13.0
2
/ -25 + * - 2 3 4 / 8 4
12.5
3
/ 5 + * - 2 3 4 / 8 2
ERROR
4
+10.23
10.2

代码如下:

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <stack>
using namespace std;
char s[47];
stack<double>ss;

int is_op(char c)
{
	if(c=='+' || c=='-' || c=='*' || c=='/')
		return 1;
	return 0;
}
int main()
{
	while(gets(s))
	{
		while(!ss.empty())//清空
		{
			ss.pop();
		}
		int len = strlen(s);
		int cc = 1;
		double tsum = 0;
		int flag = 0;//标记是否出现零作为除数的情况
		for(int i = len-1; i >= 0; i--)
		{
			if(s[i]>='0' && s[i]<='9')
			{
				tsum+=(s[i]-'0')*cc;
				cc*=10;
			}
			else if(s[i] == '.')//小数
			{
				tsum = tsum/(cc*1.0);
				cc = 1;
			}
			else if((s[i]=='+'||s[i]=='-') && tsum!=0)
			{
				if(s[i] == '+')
				{
					ss.push(tsum);
					i--;//跳过下一个空格
					continue;
				}
				else
				{
					tsum = -tsum;
					ss.push(tsum);
					i--;//跳过下一个空格
					continue;
				}

			}
			else if(s[i] == ' ')//其中一个运算数已经统计完
			{
				ss.push(tsum);
				tsum = 0;
				cc = 1;
				continue;
			}
			else if(is_op(s[i]))//如果是运算符
			{
				double a = ss.top();
				ss.pop();
				double b = ss.top();
				ss.pop();
				double tt = 0;
				if(s[i] == '+')
					tt = a+b;
				else if(s[i] == '-')
					tt = a-b;
				else if(s[i] == '*')
					tt = a*b;
				else if(s[i] == '/')
				{
					if(b == 0)
					{
						flag = 1;
						break;
					}
					tt = a/b;
				}
				ss.push(tt);
				i--;//跳过下一个空格
			}
		}
		/*int k = 0;//记录最后栈内还剩有的数字有多少个,有多个则ERROR
		int lenn = ss.size();
		double tt;
		for(int i = 0; i < lenn; i++)
		{
			tt = ss.top();
			ss.pop();
			if(!is_op(tt))
			{
				k++;
			}
		}
		if(flag != 1)
			printf("%.1lf\n",tt);*/
		if(flag != 1)
			printf("%.1lf\n",ss.top());
		else
			printf("ERROR\n");
	}
	return 0;
}
时间: 2024-08-14 15:51:14

3-07. 求前缀表达式的值(25) (ZJU_PAT数学)的相关文章

02-线性结构3. 求前缀表达式的值(25)

02-线性结构3. 求前缀表达式的值(25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之

pat02-线性结构3. 求前缀表达式的值(25)

02-线性结构3. 求前缀表达式的值(25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之

求前缀表达式的值

算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式说明: 输出前缀表达式的运算结果,精确到小数点后1位,或错误信息“ERROR”. 样例输入与输出: 序号 输入 输出 1 + +

7-21 求前缀表达式的值

7-21 求前缀表达式的值(25 分) 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式: 输出前缀表达式的运算结果,保留小数点后1位,或错误信息ERROR. 输入样例: + + 2

7-21 求前缀表达式的值(25 分)

前缀表达式的计算机求值:从右至左扫描表达式,遇到数字时,将数字压入堆栈,遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算(栈顶元素 op 次顶元素),并将结果入栈:重复上述过程直到表达式最左端,最后运算得出的值即为表达式的结果.例如前缀表达式"- × + 3 4 5 6":(1) 从右至左扫描,将6.5.4.3压入堆栈:(2) 遇到+运算符,因此弹出3和4(3为栈顶元素,4为次顶元素,注意与后缀表达式做比较),计算出3+4的值,得7,再将7入栈:(3) 接下来是×运算符,因此

求前缀表达式的值(25)

这道题用到了栈,所以就用C++来做咯 当然C也可以做,不过就显得麻烦了. /*--------------------------------------*/ 我们把这道题分成几个部分 1. 输入部分 怎么判断输入的是一个运算符还是一个数? 2. 计算部分 前缀表达式如何计算?在什么情况下我们可以说前缀表达式有错,而报出一个"ERROR"? 首先创建了一个表达式栈expression用来存表达式的内容 第一部分的思路是这样的,每次从输入流获取一个字符串string 1.如果string

【Zhejiang University PATest】02-3. 求前缀表达式的值

算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.前缀表达式指二元运算符位于两个运算数之前,例如2+3*(7-4)+8/4的前缀表达式是:+ + 2 * 3 - 7 4 / 8 4.请设计程序计算前缀表达式的结果值. 输入格式说明: 输入在一行内给出不超过30个字符的前缀表达式,只包含+.-.*.\以及运算数,不同对象(运算数.运算符号)之间以空格分隔. 输出格式说明: 输出前缀表达式的运算结果,精确到小数点后1位,或错误信息“ERROR”. 样例输入与输出: 序号 输入 输出 1 + +

PAT 线性结构3. 求前缀表达式的值 栈的应用

题目链接: 前缀表达式求值 题解: 同后缀表达式求值思路: 遇到数值则入栈,遇到操作符则从栈中取出最上面的两个数值进行操作,再将结果入栈,最后得到的栈顶元素则为答案. 前缀表达式从后往前遍历即可. 代码: #include<iostream> #include<cstdio> #include<cstring> #include<stack> using namespace std; int op(char a) { if(a=='+'||a=='-'||a

【PAT】2-3 求前缀表达式的值

求值方法: 对于一个前缀表达式的求值而言,首先要从右至左扫描表达式,从右边第一个字符开始判断,如果当前字符是数字则一直到数字串的末尾再记录下来,如果是运算符,则将右边离得最近的两个“数字串”作相应的运算,以此作为一个新的“数字串”并记录下来.一直扫描到表达式的最左端时,最后运算的值也就是表达式的值.例如,前缀表达式“- 1 + 2 3“的求值,扫描到3时,记录下这个数字串,扫描到2时,记录下这个数字串,当扫描到+时,将+右移做相邻两数字串的运算符,记为2+3,结果为5,记录下这个新数字串,并继续