- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
!实验二报告
《数据结构与算法设计》
实验报告
——实验二
学院:自动化学院
班级学号:1120111615
姓名:王硕
实验目的
1、熟悉VC6.0环境,使用C++语言编写一个能进行幂、求余和四则运算的简单计算器。
2、在编程与上机调试的过程中,加深对栈这一数据结构知识点的理解。
3、锻炼自我逻辑思维和动手能力编程思想技
二、实验内容
请按照四则运算加、减、乘、除、幂(^)和括号的优先关系和惯例,编写计算器程序。要求:
从键盘输入一个完整的表达式,以回车作为表达式输入结束的标志。
输入表达式中的数值均为大于等于零的整数。中间的计算过程如果出现小数也只取整。
例如,输入:4+2*5= 输出:14
输入:(4+2)*(2-10)= 输出:-48
三、程序设计
1、概要设计
(1)抽象数据类型定义
ADT Stack{
数据对象:D=
数据关系:R1=
约定端为栈顶,端为栈底。
基本操作:
Pop_OPTR(char *str)
操作结果:运算符出栈,如果成功返回1,否则返回0
Pop_OPND(int *d)
操作结果:数字出栈,如果成功返回1, 否则返回0
char_to_int(char str, char *str1)
初始条件:(str1 = 0 str1 = 9 )||str1==.
操作结果:把小数转换为整型变量
Precede(char a, char b)
操作结果:返回两个运算符的优先级
Push(char str)
初始条件:需要进栈及求值操作
操作结果:中间步骤不必运算返回0,分母为零返回1 否则返回2
EvalExpr()
初始条件:输入表达式合法
操作结果:返回表达式的最终结果。
}ADT Stack
(2)宏定义
#include iostream
using namespace std;
#include stdlib.h
#include math.h
#define MAX_SIZE 200
(3)主程序流程
(4) 模块调用关系
程序分为下述模块,且调用关系由上至下为:
主函数模块——执行输入操作,并调用计算表达式模块
计算表达式模块——每次读取一个字符,判断其为运算符还是数值,还是结束符
数值转换模块——把数值转换成整数
返回结果模块——入栈返回0,优先级高的前提下根据运算符返回中间结果
优先级判断模块——返回两个运算符的优先级
运算符出栈模块
数字出栈模块
2、详细设计
1)数据类型设计 struct STACK{
char expression[MAX_SIZE];//表达式最大长度
int top; //栈头
}stack;
2)各模块的基本操作设置
int Pop_OPTR(char *str)//运算符的出栈,如果成功返回1, 否则返回0
int Pop_OPND(int *d) //数字的出栈,如果成功返回1,否则返回0
char Precede(char a, char b) //返回两个运算符的优先级
int char_to_int(char str, char *str1) //把数字从char型转化成int,小数点后不计
int Push(char str) //表达式错误返回0 分母为0返回1 否则返回2
EvalExpr()//表达式错误返回0 分母为0返回1 否则返回2
四、程序调试分析
1、问题与改进措施
最初的时候,缺少if语句判断,使得1/0这样的式子没有报错,出现了输出结果。在优先级的比较中出现了细节的问题。
2、体会与收获
流程图很重要,本来想一上来就把程序编出来。但是觉得很混乱。但是在流程图与模块化设计以后,很多问题迎刃而解。程序讲究严谨,要规范,严谨与规范的程序是解决问题最根本也是最重要的东西。
五、用户使用说明
1、本程序的运行环境为Windows操作系统下的Microsoft Visual C++ 6.0。
2、在VC环境下打开程序后,先按照提示输入要操作的次数,然后输入表达式,务必以等号结尾,返回Error为输入表达式有错误。
3、按下任意键退出。
六、程序运行结果
测试样例1:
测试样例2:
七、程序清单
#include iostream
using namespace std;
#include stdlib.h
#include math.h
#define MAX_SIZE 200
char oper[10] = +-*%/^()#;
char ges;
char prio[9][9] = { //判断优先级
// + - * % / ^ ( ) #
/* + */ ,,,,,,,,,
您可能关注的文档
- 工程经济学第一讲.ppt
- 职业技能鉴定国家题库统一试卷 中级汽车维修检验工知识试卷.doc
- 移动广告模式创新.docx
- 2011考研英语(一)全真冲刺试卷(朱泰祺)_部分2.pdf
- 2004年4月全国机电一体化系统设计试卷.doc
- 模三测试答案.doc
- 银行从业模拟真题+答案.doc
- b三相异步电动机的运行特性.doc
- 风湿病的发病原因与预防因素.doc
- 《必修1》模块检测试题.doc
- 半导体材料性能提升技术突破与应用案例分析报告.docx
- 半导体设备国产化政策支持下的关键技术突破与应用前景报告.docx
- 剧本杀市场2025年区域扩张策略研究报告.docx
- 剧本杀行业2025人才培训体系构建中的市场需求与供给分析.docx
- 剧本杀行业2025年人才培训行业人才培养模式创新与探索.docx
- 剧本杀行业2025年内容创作人才需求报告.docx
- 剧本杀行业2025年区域市场区域剧本市场消费者满意度与市场竞争力研究报告.docx
- 剧本杀市场2025年区域竞争态势下的区域合作策略分析报告.docx
- 剧本杀行业2025人才培训与行业人才培养模式创新.docx
- 剧本杀行业剧本创作人才心理素质培养报告.docx
最近下载
- 珠心算家长会(金)课件.ppt VIP
- 税法(第5版)课件 曹越 第1--5章 税法基本原理、增值税--- 企业所得税.pptx
- 手外科疾病诊断与治疗.pptx VIP
- 2021乒乓球比赛活动设计方案.docx VIP
- 医疗器械分类目录2002版.doc VIP
- JBT10216-2013电缆桥架标准将代替JBT10216-2000旧标准.docx VIP
- 非遗知识文化云肩知识介绍PPT课件.pptx VIP
- 人行地通专项施工方案.doc VIP
- 阳江核电厂疏浚(清淤)项目环境影响报告书.docx VIP
- 2025广西公需科目考试答案(3套,涵盖95_试题)一区两地一园一通道建设;人工智能时代的机遇与挑战.pdf VIP
文档评论(0)