九度OJ—题目1019:简单计算器
来源:互联网 发布:飞飞cms 编辑:程序博客网 时间:2024/04/30 03:56
- 题目描述:
- 读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。
- 输入:
- 测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。
- 输出:
- 对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。
- 样例输入:
1 + 24 + 2 * 5 - 7 / 110
- 样例输出:
3.0013.36
网上看到的一个牛逼的代码,觉得很赞,分享下
#include "stdio.h" #include "string.h" #define MAX 1001 double stack[MAX]; int tail; int main(){ int a; char ch; while(scanf("%d",&a)&&a!=0){ ch=getchar(); tail=0; stack[++tail]=1.0*a;//tail始终指向末尾数字位置 //1.入栈所有数据(如果遇到*/号,只更新栈尾) char ch1,ch2; while(scanf("%c %d%c",&ch1,&a,&ch2)!=EOF){ if(ch1=='+'){ stack[++tail]=1.0*a;//push }else if(ch1=='-'){ stack[++tail]=-1.0*a;//push neg }else if(ch1=='*'){ stack[tail]=stack[tail]*a;//update tail }else if(ch1=='/'){ stack[tail]=stack[tail]/(double)a;//updata tail } if(ch2!=' ')break; } //2.把栈里头的东西全部加起来,求和 double result=0; for(int i=1;i<=tail;i++)result+=stack[i]; printf("%.2lf\n",result); } return 0; }/************************************************************** Problem: 1019 User: vhreal Language: C++ Result: Accepted Time:0 ms Memory:1028 kb****************************************************************/
0 0
- 九度oj 题目1019:简单计算器
- 九度OJ-题目1019:简单计算器
- 九度OJ 题目1019:简单计算器
- <九度 OJ>题目1019:简单计算器
- 九度OJ 题目1019:简单计算器
- 九度 OJ 题目1019:简单计算器
- 九度OJ-题目1019 简单计算器
- 九度OJ题目1019:简单计算器
- 题目1019:简单计算器 九度OJ
- 九度OJ—题目1019:简单计算器
- 九度OJ 1019 简单计算器
- 九度oj-1019:简单计算器
- 九度oj-1019-简单计算器
- 九度OJ 1019:简单计算器
- 九度OJ-1019-简单计算器
- 九度OJ-1019简单计算器
- 九度OJ 1019 简单计算器
- 【九度oj】1019简单计算器
- POJ 3020 Antenna Placement(二分图匹配)
- mysql 索引
- ehcache通用controller
- Android之断点续传下载
- 欧几里得算法小结
- 九度OJ—题目1019:简单计算器
- iBatis简单入门教程(oracle)
- LeetCode:Remove Element
- 汽车百科系列之(十五): 揭开DSG的面纱
- cocos2d-x-3.3rc0退出抖动问题
- ajax跨域?(jsonp)
- SpringMVC加载配置Properties文件的几种方式
- poj3126--Prime Path(广搜)
- 判断应用是否第一次启动并为其设置用户指导界面