下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、/ / /实验一:表达式求值 /文件名:stack.h /文件功能:程序中栈的实现,这里是用链式存储 /时间:2009年4月10日 / #ifndef STACK_H_INCLUDED #define STACK_H_INCLUDED #include #include #include #include #include using namespace std; #define SIZE 100 template struct node ElemType elem; node *next; ; / / /定义栈 / template class stack private: node *to
2、p; /头结点 public: / / /使用构造函数初始化 / stack() top = new node; top-next = NULL; top-elem = 0; / / /使用析构函数销栈 / stack() node *p = this-top; while (p-next != NULL) top = p-next; delete p; p = top; delete p; / / /压栈 / void push(ElemType e) node *p; p = new node; p-elem = e; p-next = this-top-next; this-top-ne
3、xt = p; / / /出栈 / void pop(ElemType &e) node *p; if(!IsEmpty() e = this-top-next-elem; p = this-top-next; this-top-next = p-next; delete p; / / /得到栈顶元素 / void GetTop(ElemType &e) e = this-top-next-elem; / / /判断栈是否为空 / bool IsEmpty(void) if (this-top-next = NULL) return true; else return false; ; #en
4、dif / STACK_H_INCLUDED /stack.h文件结束 / / /实验一:表达式求值 /文件名:ExpEvaluate.h /文件功能:实现表达式的中缀转换成后缀,并且计算出结果 /时间:2009年4月10日 / #ifndef EXPEVALUATE_H_INCLUDED #define EXPEVALUATE_H_INCLUDED #include stack.h class expr private: char ExpSIZE; char PostExpSIZE; double _value; public: expr() _value = 0; for (int i=0
5、; iSIZE; i+) Expi = 0; PostExpi= 0; void init(void) for (int i=0; iSIZE; i+) Expi = 0; PostExpi= 0; / / /得到该表达式计算后的结果 / double GetValue(void) return _value; / / /判断用户输入的表达式是否为合法的 / bool IsLegal(char *a) char tempSIZE; char test; int length = strlen(a); int left=0,right=0; int isnumber=0, ischar=0; i
6、f(length = 0) cout输入为空,请输入表达式!endl; return false; for(int i=0; iSIZE; i+) tempi = 0; / /过滤掉空格 for(int i=0,k=0; ilength; i+,k+) test = ai; if(test = ) k-; continue; tempi = test; strcpy(a,temp); length = strlen(a); / /长度不合法 for(int i=0; i SIZE) cout存储空间不够!endl; exit(0); / /处理数字与括号间省略括号的情况 for(int j=0
7、,k=0; j=0 & aj-1=9) | aj-1 = ) tempk = *; /添上省略的括号 tempk+1 = test; k+; continue; tempk = test; strcpy(a,temp); length = strlen(a); for(int i=0; iSIZE; i+) tempi = 0; / /处理负数问题 for(int j=0,k=0; jlength; j+,k+) test = aj; if(j=0 & test = -) tempk = 0; /第一个数是负数的时候,在最前面加一个负号 tempk+=-; continue; if(test
8、= ( & aj+1 = -) tempk = (; /遇到加括号的负数时,在括号和负号之间添上一个0 tempk+1 = 0; tempk+2 = -; k+=2; j+; continue; tempk = test; strcpy(a,temp); length = strlen(a); / /判断有没有非法的字符 for(int m=0; mlength; m+) test = am; if(!(test=+|test=-|test=*|test=/|test=|test=(|test=)|(test=0)|test=.) cout含有非法的字符!endl; return false;
9、 / / /检测括号是否匹配 for(int m=0; mlength; m+) test = am; if(test = () left+; if(test = ) right+; if(left != right) cout括号不匹配!endl; return false; / /判断表达式的一些数字与符号的错误 for(int p=0; plength; p+) test = ap; / /判断小数的非法 if(test=.) if(p=0 | p=length-1) cout小数点有错误!9 & ap+19 & ap-10) cout小数点有错误!endl; return false;
10、 / /判断运算符和数字的数量是否合法 if(test=0) | test=.) while(test=0 | test= .) test = a+p; isnumber+; p-; continue; if(test=+|test=-|test=*|test=/|test=) ischar+; continue; /符号数量少 if(isnumber ischar+1) cout缺少符号!endl; return false; /数字数量少 if(isnumber ischar+1) cout缺少数字!endl; return false; return true; / / /使用提供的字符
11、串来设置表达式前缀的值 / bool SetExp(char* a) if (IsLegal(a) strcpy(Exp, a); return true; else cout输入的表达式不合法!请重新输入!endl; return false; / / /将表达式前缀转换为后缀,这里优先级已经体现在程序中,没有另外建立判断函数 / void translate(void) stack oprate; char temp = *Exp; char Top; char elem; int j=0; for (int i=0; temp != 0; i+) temp = *(Exp+i); swi
12、tch (temp) case (: /遇左括号进栈 oprate.push(temp); break; case ): if (!oprate.IsEmpty() /遇右括号一直出栈直到栈顶为左括号,并且将左括号删除 oprate.GetTop(Top); while (Top != () oprate.pop(elem); PostExpj+ = elem; if (!oprate.IsEmpty() oprate.GetTop(Top); else break; oprate.pop(elem); break; case +: case -: /遇加减号优先级相同,可以一同处理 if (
13、!oprate.IsEmpty() oprate.GetTop(Top); while (Top != () oprate.pop(elem); PostExpj+ = elem; if (!oprate.IsEmpty() oprate.GetTop(Top); else break; oprate.push(temp); break; case : if (!oprate.IsEmpty() oprate.GetTop(Top); while (Top=) /优先级最高 oprate.pop(elem); PostExpj+ = elem; if (!oprate.IsEmpty() op
14、rate.GetTop(Top); else break; oprate.push(temp); break; case *: case /: /乘除法优先级也是相同的 if (!oprate.IsEmpty() oprate.GetTop(Top); while (Top=* | Top=/ | Top=) oprate.pop(elem); PostExpj+ = elem; if (!oprate.IsEmpty() oprate.GetTop(Top); else break; oprate.push(temp); break; case : /过滤空格 break; default:
15、 /处理数字,并以#号作为数字结束符号 while (temp=0 & temp=9) | temp=.) PostExpj+ = temp; i+; temp = *(Exp+i); i-; PostExpj+ = #; break; while (!oprate.IsEmpty() oprate.pop(elem); PostExpj+ = elem; PostExpj = 0; / / /计算后缀表达式的值 / bool ComputeValue(void) stack number; char temp = *PostExp; /用来暂存字符 double one=0, two=0,
16、value=0; /运算的数和结果 double date = 0, ispoint = 0; int count=0; int length = strlen(PostExp); /后缀表达式的长度 for (int i=0; ilength; i+) temp = *(PostExp+i); switch (temp) case +: /遇到加号将数字出栈,进行运算 one = 0; two = 0; value = 0; number.pop(one); number.pop(two); value = one + two; number.push(value); break; case
17、 -: /遇到号将数字出栈,进行运算 one = 0; two = 0; value = 0; number.pop(one); number.pop(two); value = two - one; number.push(value); break; case *: /计算乘号 one = 0; two = 0; value = 0; number.pop(one); number.pop(two); value = two * one; number.push(value); break; case /: /计算除号 one = 0; two = 0; value = 0; number
18、.pop(one); number.pop(two); if (one != 0) value = two / one; else cout除零错误!退出 0) value = pow(two, one); else cout错误!退出=0 & temp =9) | temp=.) if(temp = .) /遇到小数点然后后面的数字计算方式会改变 ispoint = 1; i+; temp = *(PostExp+i); continue; if (ispoint=0) date=date*10+temp-0; else count+; date += (temp-0)*pow(0.1,count); i+; temp = *(PostExp+i); i-; number.push(date); number.pop(_value); return true; / / / /将表达式的中缀式和后缀式以及最终的结果打印输出 / void Display(v
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年度跨境电商运营个人劳务用工合同范本4篇
- 2025年度新型材料门窗研发与安装合同3篇
- 2025年度个人房屋建设工期延误赔偿合同模板4篇
- 二零二五年度个人消费贷款合同规范文本4篇
- 工程进水排水承包合同(2篇)
- 二零二五版钢筋防腐处理及采购合同3篇
- 中国民用机场行业展望2025年1月 -中诚信
- 二零二五版项目负责人任期责任与权益合同3篇
- 2025年铁路货物安全运输全面保障合同3篇
- 呼叫中心述职报告2000字【三篇】
- 2024年社区警务规范考试题库
- 2024-2030年中国户外音箱行业市场发展趋势与前景展望战略分析报告
- 家务分工与责任保证书
- 消防安全隐患等级
- 温室气体(二氧化碳和甲烷)走航监测技术规范
- 部编版一年级语文下册第一单元大单元教学设计
- 《保单检视专题》课件
- 2023山东春季高考数学真题(含答案)
- 职业卫生法律法规和标准培训课件
- 高二下学期英语阅读提升练习(二)
- 民事诉讼证据清单模板
评论
0/150
提交评论