# Calculator（后缀表达式）

16 篇文章 0 订阅

【题目要求】

Implement a calculator program based on a Reverse Polish notation.

【输入】

There could be several lines. Each line contains a Reverse Polish notation. The operators and operands are sepertated by spaces( there could be more than 1 spaces between input tokens).

1 2 3 - + *
1 -
2 0 /
-
1  2  +
2.2 3.25 1.1 2.5 / - 1.32 * +

【输出】

Output result of each test case and keep 4 numbers after the decimal point.
Output ‘ERROR’ if there are errors of the input test case.

ERROR
ERROR
ERROR
ERROR
3.0000
5.9092

【我的程序】

#include <stdio.h>
#include <iostream>
#include <iomanip>
#define maxSize 500
using namespace std;

class myCal
{
private:
int depth;
double a[maxSize];

public:
myCal() { depth=-1; }

void init() { depth=-1; }
int getDepth() { return depth; }
double getData() { return a[depth]; }

void myPush(double t) { a[++depth]=t; }
int myPlus() { if (depth<1) return 1; a[depth-1]+=a[depth]; depth--; return 0; }
int myMinus() { if (depth<1) return 1; a[depth-1]-=a[depth]; depth--; return 0; }
int myMultiple() { if (depth<1) return 1; a[depth-1]*=a[depth]; depth--; return 0; }
int myDivide() { if (depth<1) return 1; if (a[depth]==0) return 1; a[depth-1]/=a[depth]; depth--; return 0; }
};

int main()
{
char ch;
double t;
int flag=0;
myCal my;

cout << fixed << setprecision(4);
do
{
ch=cin.get();

if (ch=='\n')
{
if (flag==0 && my.getDepth()==0) cout<< my.getData() << endl;
else cout<< "ERROR" << endl;
flag=0;
my.init();
}

if ((ch<='9' && ch>='0') || ch=='.') { cin.putback(ch); cin>>t; my.myPush(t); }

if (ch=='+' && flag==0) flag=my.myPlus();
if (ch=='-' && flag==0) flag=my.myMinus();
if (ch=='*' && flag==0) flag=my.myMultiple();
if (ch=='/' && flag==0) flag=my.myDivide();

}while (ch!=EOF);
return 0;
}

• 1
点赞
• 0
收藏
觉得还不错? 一键收藏
• 打赏
• 0
评论
01-21 4312
08-28 2424
11-11 2149
06-28 181
02-28
10-22
02-10 7万+
04-11 789
03-27 703
04-30 621
06-03 546
07-31 409
07-31 409

### “相关推荐”对你有帮助么？

• 非常没帮助
• 没帮助
• 一般
• 有帮助
• 非常有帮助

¥1 ¥2 ¥4 ¥6 ¥10 ¥20

1.余额是钱包充值的虚拟货币，按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载，可以购买VIP、付费专栏及课程。