- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C实现计算器实验报告
实验报告
完成日期:2014 年 10 月 27 日
实验题目:完整计算器
需求分析:
请实现一个只包含加减乘除以及括号运算的简单计算器,输入格式是正确的,不需要判断。注意式子中可能会出现负数以及多余的空格,操作数也可能是多位数和小数。
概要设计:
设计方法:
1、建立一个 fuhao 栈存储符号,一个 num 栈存储数字,并将输入存储到一个 string
类型中。
2、依次读取,每次遇到符号,则将前面缓存的 string 类型数字转化成 double 类型,
并且判断 fuhao.top()是否为乘号或者除号,若是,则和 num.top()进行运算,弹出 fuhao
和 num 的栈顶,将运算结果压入 num 栈中。保证 fuhao 栈只有加号和减号。
3、在stringtodouble()函数中添加分辨是否有小数点以及负号的语句。
4、最后在用一个循环,从后往前依次读取 fuhao 和 num 栈的数据进行运算,得出结
果。
调试分析:
a、调试中遇到的问题以及解决方案:
问题:测试样例比要求的少了一个,并且每次输入测试样例数量 T 时,会输出‘0’。
原因:使用了 getline()函数,T 后面的回车被当做了第一组样例的输入。
解决方案:在输入第一组测试数据前,用 stdio.h 里面的 getchar()函数,把‘\n’读
取掉,避免影响后面的输入。
b 时间复杂度:
该程序有两处简单的一重循环,因此每一次计算的时间复杂度为 O(n)。
用户使用说明:
暂不支持括号输入计算。
支持负数、浮点数的输入计算。
测试结果:
测试样例数量:5
实验心得:
分步思想,要分步来完成一个看起来有点复杂的程序,本例中使用了先计算乘除,再计
算加减的方法,使得程序简单可读。
附录:04.cpp
#include iostream
#include stdio.h
#include stack
#include string
using namespace std;
//定义一个“jisuan”函数,参数是两个double类型数据和一个char计算符号,返回double类型的计算结果
double jisuan(double a, double b, char c) {
if (c == +)
return a + b;
else if (c == -)
return a - b;
else if (c == /)
return a / b;
else
return a*b;
}
//定义一个”stringtodouble“函数,把string转化为double类型数据
double stringtodouble(string a) {
bool isfushu = false; //判断temp第一位是否为负数
bool isxiaoshu = false; //判断是否遇到小数点
double xiaoshu = 0.1; //当前浮点数级数
int theFirstNum = 0;
if (a[0] == -) {
isfushu = true;
theFirstNum = 1;
}
double num = 0;
for (int i = theFirstNum ; i a.size() ; i++) {
if (a[i] == .)
isxiaoshu = true;
else if (!isxiaoshu)
num = num*10 + (a[i] - 0);
else if (isxiaoshu)
num = num + xiaoshu*(a[i] - 0), xiaoshu = xiaoshu*0.1;
}
return isfushu == true ? -num : num;
}
int main() {
int T;
cout 请输入测试用例数量: ;
cin T;
for (int j = 0 ; j T ; j++) {
string input;
stackcharfuhao; // 存放符号的栈
stackdoublenum; // 存放数字的栈
string temp = ;
double sum = 0;
//当第一次输入时,用getchar()来去掉输入T后面的那个\n
if (j == 0)
char nothing = getchar();
cout 计算: ;
getline(cin, input);
for (int i = 0 ; i input.s
文档评论(0)