IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> 简单计算器 -> 正文阅读

[开发测试]简单计算器

简单计算器

描述

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

输入描述:

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

输出描述:

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

示例1

输入:
1 + 2
4 + 2 * 5 - 7 / 11
0

输出:
3.00
13.36

方法一:
使用栈分别存储数据和运算符

#include<iostream>
#include<vector>
#include<algorithm>
#include<cstring>
#include<queue>
#include<stack>
#include<cctype>
#include <unordered_map>
using namespace std;
float getNum(string s, int& index){
	float re = 0;
	while(isdigit(s[index])){
		re *= 10;
		re += s[index] - '0';
		index++;
	}
	return re;
}
float cal(float a, float b, char ch){
	float re = 0;
	switch(ch){
		case '+': re = a + b;	break;
		case '-': re = a - b;	break;
		case '*': re = a * b;	break;
		case '/': re = a*(1.0) / b;	break;
	}
	return re;
}
int main(int argc, char const *argv[])
{
	string s;
	unordered_map<char, int> prority;
	prority['$'] = 0;
	prority['#'] = 1;
	prority['+'] = 2;
	prority['-'] = 2;
	prority['*'] = 3;
	prority['/'] = 3;
	while(getline(cin,s)){
		if(s == "0")	break;
		int index = 0;
		stack<char> op;
		stack<float> data;
		s += '#';
		op.push('$');
		while(index < s.size()){
			if(s[index] == ' ')
				index++;
			else if(isdigit(s[index])){
				float a = getNum(s, index);
				data.push(a);
			}else{
				if(prority[s[index]] >  prority[op.top()]){
					op.push(s[index]);
					index++;
				}else{
					float a = data.top();
					data.pop();
					float b = data.top();
					data.pop();
					char ch = op.top();
					op.pop();
					float tp = cal(b, a, ch);
					data.push(tp);
				}
			}
			//if(!op.empty())	cout<<op.top()<<endl;
			//if(!data.empty()) cout<<data.top()<<endl;
		}
		printf("%.2f\n", data.top());
	}
	return 0;
}

方法二:
按照顺序从左到右遍历,遇到*/先计算,遇到±后计算。

#include<iostream>
#include<vector>
#include<algorithm>
#include<cstring>
#include<queue>
#include<stack>
#include<cctype>
#include <unordered_map>
using namespace std;
int main(int argc, char const *argv[])
{
	double tmp;
	char ch;
	while(cin>>tmp){
		if(tmp == 0)	break;
		double ans[201];
		int index = 0;
		ans[0] = tmp;
		while(cin>>ch>>tmp){
			cout<<ch<<tmp<<endl;
			switch(ch){
				case '+': ans[++index] = tmp;break;
				case '-': ans[++index] = -tmp;break;
				case '*': ans[index] *= tmp;break;
				case '/': ans[index] /= tmp;break;
			}
			char c = cin.get();		//cin无法读入空格和回车。所以必须用get。如果用cin会在这里停住
			cout<<c<<endl;
			if(c =='\n')	break;
		}
		double re = 0;
		for (int i = 0; i < index+1; ++i)
		{
			cout<<ans[i]<<' ';
			re += ans[i];
		}
		printf("%.2f\n", re);
	}
	return 0;
}
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-08-13 12:34:55  更:2021-08-13 12:34:59 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/28 11:56:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码