简单计算器 ——HDU(1237)

简介: 简单计算器 ——HDU(1237)

题目:

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

Input

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

Output

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

Sample Input

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

Sample Output

3.00
13.36

解题思路:把每一个运算式子单独输入,第一个输入的被默认为数组第一个数,然后如果输入的字符是+或者-的话就让数组+1,如果是*或者/的话数组不变,改变当前数组中的数。

程序代码:

#include<stdio.h>
#include<string.h>
int main()
{
  int i,j,k,n,m;
  char s; 
  double a[500],sum;
  while(~scanf("%d",&n))
  {
    char ch=getchar();
    if(n==0&&ch=='\n')
      break;
    int top=1;
    sum=0;
    memset(a,0,sizeof(a));
    a[top]=n;
    while(~scanf("%c%d",&s,&m))
    {
      if(s=='+')    a[++top]=m;
      else if(s=='-') a[++top]=-m;
      else if(s=='*') a[top]=a[top]*m;
      else      a[top]=a[top]/m;
      if(getchar()=='\n')
        break;
    }
    for(i=1;i<=top;i++)
      sum+=a[i];
    printf("%.2f\n",sum);   
  }
  return 0;
} 

相关文章
|
Java 测试技术
hdu 1228 A + B
hdu 1228 A + B
47 0
|
Java
hdu 1257 最少拦截系统
hdu 1257 最少拦截系统
48 0
|
算法 Java
HDU 2084 数塔
在讲述DP算法的时候,一个经典的例子就是数塔问题,它是这样描述的: 有如下所示的数塔,要求从顶层走到底层,若每一步只能走到相邻的结点,则经过的结点的数字之和最大是多少?
174 0
|
机器学习/深度学习