hdu 1237 简单计算器

转载请注明出处: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
浙大计算机研究生复试上机考试-2006年

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;
}


你可能感兴趣的:(测试,数学,杭电)