数据结构表达式求值(可以求小数与多位数)_第1页
数据结构表达式求值(可以求小数与多位数)_第2页
数据结构表达式求值(可以求小数与多位数)_第3页
数据结构表达式求值(可以求小数与多位数)_第4页
数据结构表达式求值(可以求小数与多位数)_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论