码迷,mamicode.com
首页 > 其他好文 > 详细

杭电ACM1237——简单计算器

时间:2015-05-07 08:52:23      阅读:458      评论:0      收藏:0      [点我收藏+]

标签:acm   杭电   

简单的表达式求值,A了好久,坑。

AC的代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <stack>
using namespace std;

int main()
{
	char str, c;
	double a, b;
	stack <double> num;
	while(scanf("%lf", &a) != EOF)
	{
		while(!num.empty())
			num.pop();
		c = getchar();
		if(c == '\n' && a == 0)
			break;
		num.push(a);
		scanf("%c", &c);
		while(scanf("%lf", &b))
		{
			if(c == '*')                //优先级高,取数,计算
			{
				a = num.top();
				num.pop();
				num.push(a * b);
			}
			else if(c == '/')           //同上
			{
				a = num.top();
				num.pop();
				num.push(a / b);
			}
			else if(c == '+')           //优先级低,先存入栈
				num.push(b);
			else if(c == '-')          //减法变成加上那个数的负
				num.push(-b);
			c = getchar();
			if(c == '\n')               //结尾
				break;
			scanf("%c", &c);
			getchar();
		}
		double ans = 0.0;
		while(!num.empty())
		{
			ans += num.top();
			num.pop();
		}
		printf("%.2lf\n", ans);
	}
	return 0;
}


杭电ACM1237——简单计算器

标签:acm   杭电   

原文地址:http://blog.csdn.net/qq_25425023/article/details/45542577

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!