简单计算器 ——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;
} 

相关文章
|
12月前
hdu1406 完数 (水题)
hdu1406 完数 (水题)
46 0
|
测试技术
HDU-1228,A + B(字符串处理)
HDU-1228,A + B(字符串处理)
|
C++ 人工智能 BI
HDU2032杨辉三角
有点强迫症,主函数必须简洁,但是这里的if判断语句很碍眼,自己也并没有想到什么不画蛇添足的方法使代码更加简洁......
1502 0
【HDU 4451 Dressing】水题,组合数
有衣服、裤子、鞋数量分别为n,m,k,给出p对不和谐的衣-裤或裤-鞋搭配,问一共有多少种和谐的衣裤鞋的搭配。 全部的组合有Cn1Cm1Ck1种。 设p对中有p1对衣-裤,p2对裤-鞋,则不和谐的搭配共有p1*Ck1+p2*Cn1种,但有被重复计算两次的搭配共p3对,它们引用了同一裤。
908 0
|
机器学习/深度学习
poj 2773 Happy2006【容斥原理】
Happy 2006 Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 9936   Accepted: 3411 Description Two positive i...
856 0
|
测试技术 Java 机器学习/深度学习