




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上精选优质文档-倾情为你奉上专心-专注-专业专心-专注-专业精选优质文档-倾情为你奉上专心-专注-专业四、实验步骤#include stdafx.h#include #include #include #include #include #define STACK_INIT_SIZE 100#define STACKINCREMENT 10#define OPSETSIZE 7typedef int Status;float Operate(float a, char theta, float b);Status In(char Test,char TestOp7);c
2、har precede(char Aop, char Bop);char OPSETOPSETSIZE=+ , - , * , / ,( , ) , #;typedef structchar *base;char *top;int stacksize;SqStackOPTR;typedef structfloat *base;float *top;int stacksize;SqStackOPND;Status InitStackOPTR(SqStackOPTR &S) /初始化栈S.base=(char *)malloc(sizeof(char) * STACK_INIT_SIZE);if(
3、!S.base)cout初始化失败;return false;elseS.top=S.base;S.stacksize=STACK_INIT_SIZE;return true;Status InitStackOPND(SqStackOPND &S) /初始化栈S.base=(float *)malloc(sizeof(float) * STACK_INIT_SIZE);if(!S.base)cout, , , , , , ,=0&exi=0&exj=9|exj=.) Hk=exj;k+; else break; /for for(i=1;ik;i+) if(Hi=.) m1=i; if(m1=
4、1) for(i=1;ik;i+) add=add*10+float(Hi-48); else for(i=1;im1;i+) add=add*10+float(Hi-48); for(i=m1+1;ik;i+) num=pow(10,m1-i)*float(Hi-48); add+=num; PushOPND(OPND,add);add=0;i=j; else / 不是运算符则进栈 switch (precede(GetTopOPTR(OPTR,x),exi) case : / 退栈并将运算结果入栈 PopOPTR(OPTR,theta); PopOPND(OPND,b); PopOPND(
5、OPND,a); m=Operate(a, theta, b); PushOPND(OPND,m); break; / switch /els / while return GetTopOPND(OPND,m); / EvaluateExpressionfloat Operate(float a,char theta, float b) switch(theta) case +: return a+b;break; case -: return a-b;break; case *: return a*b;break; case /: return a/b;break; default : re
6、turn 0;break; Status In(char Test,char TestOp7) bool status=false; for (int i=0; i OPSETSIZE; i+) if (Test=TestOpi) status= true; return status;int ReturnOpOrd(char op,char TestOp7) int i,n=0; for(i=0; i OPSETSIZE; i+) if (op=TestOpi) n=i; return n;char precede(char Aop, char Bop) return PriorReturn
7、OpOrd(Aop,OPSET)ReturnOpOrd(Bop,OPSET);void main()int i,n,C=1;char *p;while(C=1)coutn;p=new charn;cout请输入表达式(以#结束):;for(i=0;ipi;cout运算结果是:;for(i=0;in-1;i+)coutpi;cout=EvaluateExpression(p,n)endl;cout是否继续?(1:继续; 0:结束)C;五、实验结果及分析六、实验总结 通过本次实验学到了许多东西,首先编写程序要有耐心,期间有好几次都想到要放弃了,算法是正确的,但结果总是错误。但静下心来仔细考虑才发现是一个小错误、小失误导致。所以说耐心很重要。同时,和同
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 4498.1-2025橡胶灰分的测定第1部分:马弗炉法
- GB 45669.4-2025黄河流域工业用水定额第4部分:水泥
- 2025年信息处理考试深化试题及答案
- 高考语文复习突破口及试题与答案2023
- 行政管理的道德困境与试题答案解析
- 高考数学集中训练模块试题及答案
- 仓库出现火灾应急预案(3篇)
- 高考数学解题效率提升分享试题及答案
- 通信公司火灾应急预案(3篇)
- 采油树火灾应急预案(3篇)
- 《智能财务与经营分析》课程教学大纲
- 采访技巧与效率提升
- 生命科学简史知到智慧树章节测试课后答案2024年秋中国科学技术大学
- 农村电网改造项目实施方案
- 医疗纠纷防范及法律责任课件
- 公司招标书范本大全(三篇)
- 正念减压疗法详解课件
- 知识产权管理体系讲解课件
- 彩钢板除锈喷漆施工方案
- 国家开放大学(山东)《地域文化(本)》形考任务1-3+终结性考核参考答案
- 2022年高考数学试卷(上海)(秋考)(解析卷)
评论
0/150
提交评论