- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE PAGE 7一、需求分析从键盘中输入一个后缀表达式,该表达式包括加减乘除等操作符,以及正整数做诶操作数等。需要利用堆栈来实现。在Visual C++6.0界面操作。 问题描述:读入一个后缀表达式,利用堆栈来计算该表达式的值,同时要校验后缀表达式是否正确。测试数据用例(1)输入:2 3 * 1 - # 输出:5(2)输入:2 3 * 1 - * # 输出:表达式有误(3)输入: 2 0 / 4 * # 输出: 表达式有误 二、概要设计 抽象数据类型为实现上述程序的功能,则以字符型数据存储用户的输入。若为数值,则用自定义函数将其转化为整形数据;若为操作符,则仍为字符型数据,以便计算出的结果。算法的基本思想根据题目要求,采用堆栈来实现。该算法的基本思想是运用自定义函数求解逆波兰表达式求值问题问题。程序的流程程序由三个模块组成:输入模块:完成表达式的输入,存入栈S中。计算模块:利用自定义函数,计算逆波兰表达式的值。输出模块:屏幕上显示出最终计算结果。三、详细设计物理数据类型程序中要求输入的表达式为任意的,但必须以#标志表达式输入的结束,只有正确的逆波兰表达式才能显示出最终计算结果。算法的具体步骤算法的具体步骤为:建立一个名为s的栈。将表达式的值一个个压入栈S中。在循环中,需要分类讨论:如果表达式中的值为“#”,则将#前的元素弹出栈中;如果表达式中的值为空格,那么继续压入,如果表达式中的值为0至9的字符,则要通过一个自定义的转换函数将其转换为int型数值;如果连续几个0至9的字符中间无空格隔开,则在计算中应将其还原为多位数;若表达式中的值为运算符,则要将栈S中所压入数值弹出栈,进行相应的计算后,再将结果压入栈中(值得注意的是,运算符是不入栈的);除此之外的情况都归类为输入的表达式错误。相应的入栈出栈及数值计算部分都由自定义函数来完成。输入和输出的格式输入 在字符界面上输入一个后缀表达式,其中两相邻操作数之间利用空格隔开。以“#”表示结束。输出如果该后缀表达式正确,那么在字符界面上输出其结果,计算结果小数点后面保留两位有效数字,如果不正确,请在字符界面上输出表达式错误提示。四、调试分析 略。(已在老师面前调试)五、测试结果 六、实验心得(可选)本次实验是我第一次接触用栈来编写的程序,发现自己对栈的定义及使用还是不够熟悉;发现自己的逻辑严密性不够,在今后的编程过程中要注意加强这方面的能力。(这个C程序是老师给我们调试了两节课所得,并不是我做实验的程序,但是觉得这个程序给我印象更深刻,故写入实验报告。)七、附录(可选)//用栈来实现逆波兰式求值问题#includestdio.h#includestdlib.h#define STACK_INIT_SIZE 100//栈的存储空间初始分配#define STACKINCREMENT 10// 存储空间分配增量#define TRUE 1#define False 0#define OK 1#define ERROR 0#define INFEASIBLE -1#define OVERFLOW -2typedef int Status;//相当于定义一个数据结构类型typedef int SElemtype;typedef struct{ SElemtype *base; int top; int stacksize;} SqStack;Status InitStack(SqStack S ){ S.base = (SElemtype *)malloc(STACK_INIT_SIZE*sizeof(SElemtype)); if (! S.base) exit(OVERFLOW); S.top = -1; S.stacksize = STACK_INIT_SIZE; return OK;}int StackLength(SqStack S) {//获得堆栈元素的个数 return S.top+1;}Status Push(SqStack S, SElemtype e){//入栈//填空 if(S.top ==99) {//栈满 return ERROR; } S.base[++S.top] = e; return OK;}Status Pop(SqStack S, SElemtype e){//出栈 if(S.top==-1)return ERROR; e=S.base[S.top--]; return OK;}Status IsDigital(char ch){ if(ch=0ch=9) { return 1; return 0; } int EvalValue(char *ch, SqStack S) {
文档评论(0)