已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/*表达式求值,输入一个表达式,如1+2*3#,程序可计算出结果为7支持以下符号:+ - * / ( ) .可以计算整数、小数其中表示次方,25表示2的5次方*/*头文件*/#include #include #include #include #include /*宏定义*/#define INIT_STACK_SIZE 100#define SET_NUM 8#define N 100/*字符优先级表*/unsigned char priorSET_NUMSET_NUM = /* + - * / ( ) # */ /*+*/, , , , , , , , , , , , , , , , , , , , , , , , , /*(*/, , , , , =, , , , , , , , , , /*#*/, , , , , , =, , , , , , , ; unsigned char priorSetSET_NUM = +, -, *, /, (, ), #, ;/*结构体定义,这是用来存放字符的栈*/typedef structchar *base;char *top;int stacksize; SqStackC;/*结构体定义,这是用来存放数字的栈*/typedef structdouble *base;double *top;int stacksize; SqStackN;void initStackN(SqStackN &);void initStackC(SqStackC &);void pushN(SqStackN &, double);void pushC(SqStackN &, double);void popN(SqStackN &, double &);void popC(SqStackN &, double &);double calculate(double, char, double);int findInSet(char);char compare(char, char);void getSolution();/*主函数*/void main()getSolution();/*初始化数字栈*/void initStackN(SqStackN &S)S.base = (double*) malloc(INIT_STACK_SIZE * sizeof(double);S.top = S.base;S.stacksize = INIT_STACK_SIZE;/*初始化字符栈*/void initStackC(SqStackC &S)S.base = (char*) malloc(INIT_STACK_SIZE * sizeof(char);S.top = S.base;S.stacksize = INIT_STACK_SIZE;/*向数字栈中存放数字*/void pushN(SqStackN &S, double x)if (S.top-S.base = S.stacksize) return;*(S.top+) = x;/*向字符栈中存放字符*/void pushC(SqStackC &S, char x)if (S.top - S.base = S.stacksize) return;*(S.top+) = x;/*从数字栈中取出数字*/void popN(SqStackN &S, double &x)if (S.top=S.base) return;x = *(-S.top);/*从字符栈中取出字符*/void popC(SqStackC &S, char &x)if (S.top = S.base) return;x = *(-S.top);/*这个函数返回a operation b的值。假如operation为+,则返回a+b的值*/double calculate(double a, char operation, double b)/*判断operation,返回对应的计算结果*/switch (operation) case +:return a + b;case -:return b - a;case *:return a * b;case /:return b / a;case :return pow(b, a);default:return 0;/*查找字符c在priorSet中的什么位置*/*priorSet是所支持的所有字符的集合*/int findInSet(char c)int i;for (i = 0; i = 0 & tempi = 0 & tempi :/*取出字符栈顶运算符,和数字栈顶的两个数字*/popC(OPTR, operation);popN(OPND, a);popN(OPND, b);/*计算结果*/sum = calculate(a, operation, b);/*结果入栈*/pushN(OPND, sum);break;/*如果优先级小*/case :/*入栈,继续循环*/pushC(OPTR, tempi);i+;break;/*如果优先级相等*/case =:/*优先级相等只
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 临床皮肌炎疾病影像表现
- 销售会计工作职责
- 热性惊厥患儿的护理教育与培训方法
- 贵州省六盘水市2026届高考冲刺语文模拟试题含解析
- 医学26年:睡眠呼吸暂停诊疗 查房课件
- 26年老年辅助器具总结课件
- 26年基础护理技能直播脚本课件
- 【2025】葫芦岛市龙港区双龙街道工作人员招聘考试真题
- 26年社区老年群体生理护理
- 医学26年:出血性疾病指南更新 查房课件
- 2024年国网安徽省电力有限公司高校毕业生招聘考试真题
- 2025年内蒙古兴安盟工会招聘社会化工会工作者考试笔试试题含答案
- 文物安全文件解读课件
- 考叉车证科目一模拟试题
- 充电站安全生产责任制
- 串串店加盟易合同范本
- 2025年检察院书记员考试真题(附答案)
- 新闻编辑实践作业汇报
- 电力拖动自动控制系统-运动控制系统(第5版)习题答案
- JG/T 355-2012天然石材用水泥基胶粘剂
- 合伙贷款合同协议书
评论
0/150
提交评论