版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、批阅实 验 报 告 年级 班号 学号 姓名 实验名称: 栈的实现及其应用:算术表达式的计算 实验日期 2016年12月 2日实验报告撰写内容一、实验环境二、实验目的三、实验内容四、数据结构与算法思想描述五、程序清单六、程序执行结果及其分析计算机科学与技术系2016年制一、 实验环境32位操作系统下的Window平台 Microsoft Visual C+二、 实验目的掌握栈的实现及使用三、 实验内容1.实现栈的存储结构2.实现栈的基本操作的有关算法3.利用栈解决*算术表达式求值问题四、 数据结构与算法思想描述顺序读取中缀表达式:1、 当遇到数字时,将数字入数字栈2、 当遇到操作符时,与操作符栈
2、栈顶比较:If(当前操作符优先级大于操作符栈栈顶的优先级)If(非”)”操作符)将当前操作符进操作符栈;ElseWhile(操作符栈栈顶不等于”(“)取操作符栈栈顶及数字栈的两个数进行运算,并将结果压入数字栈;ElseIf(非(“操作符)While(操作符栈栈顶不等于”(“)取操作符栈栈顶及数字栈的两个数进行运算,并将结果压入数字栈;Continue;(直到当前操作符比栈顶操作符优先级大)Else将当前操作符进操作符栈;3、 While(操作符栈非空)操作符栈栈顶及数字栈的两个数进行运算,并将结果压入数字栈;4、 在数字栈取最后结果并输出。五、 程序清单/10*82+16.3+5*(5.2*5
3、+3.01)/4-(-10)+0.1000060+4.00416-40 = 666.666666/100+(-100)-(-102) = 100/(2016-2017+(2015-2014) = 0/-1+(10)+100%102 = 0#include<iostream>#include<stdio.h>#include<math.h>#include<string.h>#include<iomanip>#include<map>using namespace std;const int MAX = 105;typede
4、f double Type;typedef structType TypeStackMAX;char charStackMAX;int TypeTop, charTop;Stack;/初始化栈void InitStack(Stack *S)S->charTop = S->TypeTop = 0;/判断charStack是否为空bool IsEmpty_Char(Stack S)return S.charTop = 0;/判断TypeStack是否为空bool IsEmpty_Type(Stack S)return S.TypeTop = 0;/判断charStack是否为满bool
5、 IsFull_Char(Stack S)return S.charTop = MAX;/判断TypeStack是否为满bool IsFull_Type(Stack S)return S.TypeTop = MAX;void Push_Char(Stack *S, char ch)/charStack不为满则入栈,否则输出提示if(!IsFull_Char(*S)S->charStackS->charTop+ = ch;elsecout << " The CharStack Is Full! " << endl;void Push_Typ
6、e(Stack *S, Type a)/TypeStack不为满则入栈,否则输出提示if(!IsFull_Type(*S)S->TypeStackS->TypeTop+ = a;elsecout << " The TypeStack Is Full! " << endl;char Pop_Char(Stack *S)if(!IsEmpty_Char(*S)S->charTop-;return S->charStackS->charTop;elsecout << " The CharStack Is
7、Empty! " << endl;return -1;Type Pop_Type(Stack *S)if(!IsEmpty_Type(*S)S->TypeTop-;return S->TypeStackS->TypeTop;elsecout << " The TypeStack Is Empty! " << endl;return -1;char Top_Char(Stack S)if(!IsEmpty_Char(S)return S.charStack-S.charTop;elsecout <<
8、" The CharStack Is Empty! " << endl;return -1;Type Top_Type(Stack S)if(!IsEmpty_Type(S)return S.TypeStack-S.TypeTop;elsecout << " The TypeStack Is Empty! " << endl;return -1;Type Calculate(Type left, Type right, char op)Type value = 0;switch(op)case '+':
9、value = left + right;break;case '-':value = left - right;break;case '*':value = left * right;break;case '/':if(right != 0)value = left / right;elsecout << "被除数不能为零!" << endl;break;case '%':if(right != 0)value = (int)left % (int)right;elsecout <
10、;< "被余数不能为零!" << endl;break;case '':value = pow(left,right);/*value = 1;if(right >= 0)while(right-)value *= left;elseright = -right;while(right-)value /= left;*/return value;void Computer(char *mid_equotion, Type len)Type right, left , result;char *p_mid_equotion = mid_
11、equotion;char after_equotion = ' 'map<char,Type> Oper;Oper'#' = 1;Oper'(' = 2;Oper'+' = 3;Oper'-' = 3;Oper'*' = 4;Oper'/' = 4;Oper'%' = 4;Oper'' = 5;Oper')' = 6;Stack MyStack;InitStack(&MyStack);Push_Char(&
12、MyStack,'#');char top_oper, current_oper;for(;*p_mid_equotion != '0')top_oper = Top_Char(MyStack);current_oper = *p_mid_equotion;if(!Opercurrent_oper)Push_Type(&MyStack,strtod(p_mid_equotion, &p_mid_equotion);continue;/end ifelse/为操作符if(Opercurrent_oper > Opertop_oper)if(c
13、urrent_oper != ')')Push_Char(&MyStack,current_oper);elsewhile(top_oper != '(')right = Pop_Type(&MyStack);if(!IsEmpty_Type(MyStack)left = Pop_Type(&MyStack);elseleft = 0;Push_Type(&MyStack,Calculate(left, right, Top_Char(MyStack);Pop_Char(&MyStack);top_oper = Top_C
14、har(MyStack);Pop_Char(&MyStack);/end else/end ifelseif(current_oper = '(')Push_Char(&MyStack,current_oper);if(*(p_mid_equotion + 1) = '-')Push_Type(&MyStack,0);elseright = Pop_Type(&MyStack);if(!IsEmpty_Type(MyStack)left = Pop_Type(&MyStack);elseleft = 0;Push_Type
15、(&MyStack,Calculate(left, right, top_oper);Pop_Char(&MyStack);continue;/end else/end elsep_mid_equotion+;/end fortop_oper = Pop_Char(&MyStack);while(top_oper != '#')right = Pop_Type(&MyStack);if(!IsEmpty_Type(MyStack)left = Pop_Type(&MyStack);elseleft = 0;Push_Type(&M
16、yStack,Calculate(left, right, top_oper);top_oper = Pop_Char(&MyStack);/cout << setprecision(6) << "nThe Result = " << (result = Pop_Type(&MyStack) << endl;printf("The Result = %lfnn",(result = Pop_Type(&MyStack);int main()char sMAX = ""Type i = 0;cout << "请输入你要求值的表达式!
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 房屋借款合同范本
- 专业策划方案企业品牌服务合同
- 产品独家代理权合同权利义务
- 音乐教育机构教师协议
- 填充墙建设劳务分包合同
- 门窗设备购销合同范本
- 室内粉刷合同班组分包
- 回迁房购房合同范本填写
- 安全信息化平台建设服务合同
- 购房合同解除的相关问题解答
- DL∕T 5362-2018 水工沥青混凝土试验规程
- 交响音乐赏析智慧树知到期末考试答案章节答案2024年西安交通大学
- 个体诊所药品清单
- 药品招商流程
- PFMEA的严重度SOD的评分和优先级别
- 国网基建国家电网公司输变电工程结算管理办法
- 100道递等式计算(能巧算得要巧算)
- 中国地图含省份信息可编辑矢量图
- 路政运政交通运输执法人员考试题库
- 企业技术标准化管理
- 投资学第19章财务分析stu
评论
0/150
提交评论