当前位置:首页 > 题解目录 > 正文内容

【题解】后缀表达式的值

亿万年的星光4年前 (2021-11-20)题解目录1609

【题目描述】


从键盘读入一个后缀表达式(字符串),只含有0-9组成的运算数及加(+)、减(—)、乘(*)、除(/)四种运算符。每个运算数之间用一个空格隔开,不需要判断给你的表达式是否合法。以@作为结束标志。

比如,16–9*(4+3)转换成后缀表达式为:16□9□4□3□+*–,在字符数组A中的形式为:

1331a.gif

栈中的变化情况:

1331b.gif


运行结果:-47

提示:输入字符串长度小于250,参与运算的整数及结果之绝对值均在264范围内,如有除法保证能整除。


【输入描述】

一个后缀表达式。

【输出描述】

一个后缀表达式的值。

【样例输入】

16 9 4 3 +*-@


【样例输出】

-47

【题目分析】

  • 要计算出最终结果肯定是要后缀转中缀。然后再计算。

  • 后缀转中缀的规则如下:

            1.从左到右,遇到数就入栈,遇到操作符就出栈

            2.运算规则是    栈底元素 op 栈顶元素

  •  另外注意 字符转数字和数字转字符


【参考答案】


#include<iostream>
#include<stack>
#include<string>
using namespace std;

stack <long long> s;//因为数据最大是2的六十四次方

int main()
{
	string a;
	long long t = -1, m, n, ans, i = 0;
	getline(cin,a);//因为有空格所以用getline,否则直接cin就可,头文件string
	while (a[i] != '@')
	{
		if (a[i] >= '0' && a[i] <= '9')
		{
			if (t == -1)//最初或者当前元素是空格,直接结果压入栈
			{
				t = a[i] - '0';
				s.push(t);
			}
			else//当前不是空格,之前的数字变成整数压入栈
			{
				t = s.top();
				s.pop();
				t = t * 10 + (a[i] - '0');
				s.push(t);
			}
		}
		if (a[i] == ' ')
		{
			t = -1;
		}
		if (a[i] == '+')
		{
			m = s.top();s.pop();n = s.top();s.pop();
			ans = m + n;
			s.push(ans);

		}
		if (a[i] == '-')
		{
			m = s.top(); s.pop(); n = s.top(); s.pop();
			ans = n-m;
			s.push(ans);
		}
		if (a[i] == '*')
		{
			m = s.top(); s.pop(); n = s.top(); s.pop();
			ans = n*m;
			s.push(ans);
		}
		if (a[i] == '/')
		{
			m = s.top(); s.pop(); n = s.top(); s.pop();
			ans = n/ m;
			s.push(ans);
		}
		i++;
	}
	 cout<<s.top();
}


扫描二维码推送至手机访问。

版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

标签: 数据结构
分享给朋友:

相关文章

【题解】愤怒的牛

【题目描述】农夫 John 建造了一座很长的畜栏,它包括N(2<=N<100000)个隔间,这些小隔间依次编号为x1,x2,...xn(0<=xi<=1000000000)。但...

【题解】大整数加法

【题目描述】求两个不超过200位的非负整数的和。【输入】有两行,每行是一个不超过200位的非负整数,可能有多余的前导0。【输出】一行,即相加后的结果。结果里不能有多余的前导0,即如果结果是342,那么...

【题解】约瑟夫问题2

【题解】约瑟夫问题2

【题目描述】M个人围成一圈,每分钟相邻的两个人可以交换位置(只能有一对交换)。求使M个人的顺序颠倒(即每个人左边相邻的人换到右边,右边相邻的人换到左边)所需的最少时间(分钟数)。【输入描述】 ...

【题解】亲戚

【题目描述】若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系。规定:x和y是亲戚,y和z是亲戚,那么x和z也是亲戚。如果x,y是...

【题解】最大配对

题目描述      给出2个序列A={a[1],a[2],…,a[n]},B={b[1],b[2],…,b[n]},从A、B中各选出n个元素进行一一配对(可以不按照原来在...

【题解】求车速问题

【题目描述】一辆以固定速度行驶的汽车,司机在上午10点看到里程表上的读数是一个对称数(即这个数从左向右读和从右向左读是完全一样的),为95859。两小时后里程表上出现了一个新的对称数。问该车的速度是多...