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

【题解】后缀表达式的值

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

【题目描述】


从键盘读入一个后缀表达式(字符串),只含有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();
}


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

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

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

相关文章

【题解】最长不下降子序列2

【题目描述】设有由n(1≤n≤200)个不相同的整数组成的数列,记为:b(1)、b(2)、……、b(n)且b(i)≠b(j)(i≠j),若存在i1<i2<i3<…<ie 且有b...

2020CSPJ-直播获奖

【题目描述】NOI2130 即将举行。为了增加观赏性,CCF 决定逐一评出每个选手的成绩,并直播即时的获奖分数线。本次竞赛的获奖率为w%,即当前排名前 w% 的选手的最低成绩就是即时的分数线...

【题解】切割钢管

【题解】切割钢管

【题目描述】小A是某工地的计算工程师。工地现有 n 根钢管,第 i 根钢管的长度为 ai。现在想用这 n 根钢管来做一个支撑用的柱子。我么可以切割这些钢管成为更短的钢管,但是不能缝合两根钢管。为了安全...

【题解】游戏

【题目描述】上了半天的物理数学课,大家的脑子有点转不动了,下午的课表似乎看透了同学们的 心思,第一节就安排了体育课,CZ 中学的课表真是太有爱了,赞一个!午间休息后,文体 委员小 S 喊大家到教室外的...

【题解】合根植物

【题解】合根植物

【题目描述】w星球的一个种植园,被分成 m * n 个小格子(东西方向m行,南北方向n列)。每个格子里种了一株合根植物。这种植物有个特点,它的根可能会沿着南北或东西方向伸展,从而与另一个格子的植物合成...

合影效果

【题目描述】小云和朋友们去爬香山,为美丽的景色所陶醉,想合影留念。如果他们站成一排,男生全部在左(从拍照者的角度),并按照从矮到高的顺序从左到右排,女生全部在右,并按照从高到矮的顺序从左到右排,请问他...