首页 > 其他 > 详细

hdu 1237 简单计算器

时间:2014-05-13 15:28:02      阅读:395      评论:0      收藏:0      [点我收藏+]

转载请注明出处:http://blog.csdn.net/u012860063

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1237



Problem Description
读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。

Input
测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。

Output
对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。

Sample Input
1 + 2 4 + 2 * 5 - 7 / 11 0

Sample Output
3.00 13.36

Source

Recommend
JGShining | We have carefully selected several similar problems for you: 1230 1256 1276 1239 1226


思路还是很简单的就是先计算 乘法和除法!

具体见代码;

代码如下:

#include <cstdio>
int main()
{
	char c[147];
	double num[147];
	int i;
	while(~scanf("%lf%c",&num[0],&c[0]))
	{
		if(num[0] == 0 && c[0] == ‘\n‘)
			break;
		else if(num[0] != 0 && c[0] == ‘\n‘)
		{
			printf("%.2lf\n",num[0]);
			continue;
		}
		scanf("%c%*c",&c[0]);
		for(i = 1 ; ; i++)
		{
			scanf("%lf%c",&num[i],&c[i]);
			if(c[i] == ‘\n‘)
			{
				break;
			}
			scanf("%c%*c",&c[i]);
		}
		char sign =‘+‘ ;//初始化为‘+‘是为了防止后面没有经过‘+‘,‘-‘直接是‘*‘,‘/‘
		for(i = 1 ;  ; i++)
		{
			if(c[i-1] == ‘+‘)
				sign = ‘+‘;
			else if( c[i-1] == ‘-‘)
				sign = ‘-‘;
			if(c[i-1] == ‘*‘)
			{
				num[i] = num[i-1]*num[i];
				num[i-1] = 0;
				c[i-1] = sign;
			}
			else if(c[i-1] == ‘/‘)
			{
				num[i] = num[i-1]/num[i];
				num[i-1] = 0;
				c[i-1] = sign;
			}
			if(c[i] == ‘\n‘)
				break;
		}
		for( i = 1 ;  ; i++)
		{
			if(c[i-1] == ‘+‘)
			{
				num[i] = num[i-1] + num[i];
			}
			else if(c[i-1] == ‘-‘)
			{
				num[i] = num[i-1] - num[i];
			}
			if(c[i] == ‘\n‘)
				break;
			
		}
		printf("%.2lf\n",num[i]);
	}
	return 0;
}


hdu 1237 简单计算器,布布扣,bubuko.com

hdu 1237 简单计算器

原文:http://blog.csdn.net/u012860063/article/details/25654051

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!