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

相关文章
|
11天前
|
存储 弹性计算 运维
简单计算器
【4月更文挑战第30天】
17 0
|
8月前
|
C语言
19:简单计算器
19:简单计算器
111 0
|
测试技术
HDU-1228,A + B(字符串处理)
HDU-1228,A + B(字符串处理)
HDOJ/HDU 1328 IBM Minus One(水题一个,试试手)
HDOJ/HDU 1328 IBM Minus One(水题一个,试试手)
81 0
HDOJ(HDU) 1799 循环多少次?(另类杨辉三角)
HDOJ(HDU) 1799 循环多少次?(另类杨辉三角)
84 0
HDOJ(HDU) 1799 循环多少次?(另类杨辉三角)
|
C++ 人工智能 BI
HDU2032杨辉三角
有点强迫症,主函数必须简洁,但是这里的if判断语句很碍眼,自己也并没有想到什么不画蛇添足的方法使代码更加简洁......
1479 0
|
Java BI 机器学习/深度学习