




免费预览已结束,剩余8页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
批阅实 验 报 告 年级 班号 学号 姓名 实验名称: 栈的实现及其应用:算术表达式的计算 实验日期 2016年12月 2日实验报告撰写内容一、实验环境二、实验目的三、实验内容四、数据结构与算法思想描述五、程序清单六、程序执行结果及其分析计算机科学与技术系2016年制一、 实验环境32位操作系统下的Window平台 Microsoft Visual C+二、 实验目的掌握栈的实现及使用三、 实验内容1.实现栈的存储结构2.实现栈的基本操作的有关算法3.利用栈解决*算术表达式求值问题四、 数据结构与算法思想描述顺序读取中缀表达式:1、 当遇到数字时,将数字入数字栈2、 当遇到操作符时,与操作符栈栈顶比较:If(当前操作符优先级大于操作符栈栈顶的优先级)If(非”)”操作符)将当前操作符进操作符栈;ElseWhile(操作符栈栈顶不等于”(“)取操作符栈栈顶及数字栈的两个数进行运算,并将结果压入数字栈;ElseIf(非(“操作符)While(操作符栈栈顶不等于”(“)取操作符栈栈顶及数字栈的两个数进行运算,并将结果压入数字栈;Continue;(直到当前操作符比栈顶操作符优先级大)Else将当前操作符进操作符栈;3、 While(操作符栈非空)操作符栈栈顶及数字栈的两个数进行运算,并将结果压入数字栈;4、 在数字栈取最后结果并输出。五、 程序清单/10*82+16.3+5*(5.2*5+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#include#include#include#include#includeusing namespace std;const int MAX = 105;typedef 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 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! TypeStackS-TypeTop+ = a;elsecout The TypeStack Is Full! charTop-;return S-charStackS-charTop;elsecout The CharStack Is Empty! 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 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 +: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 被余数不能为零! = 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_equotion;char after_equotion = ;map 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(&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(current_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_Char(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(&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(&MyStack,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 sM
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 专业资格认证证书持有者能力证明(5篇)
- 环境科学与保护研究知识考点
- 那场难忘的足球赛话题议论文14篇
- 2025年芬兰语等级考试高级冲刺试卷
- 2025年茶艺师(高级)职业技能鉴定试卷(专业能力考核测评)
- 与大自然的对话:写景并抒情的6篇
- 2025年护目镜项目规划申请报告
- 2025年电子商务师(中级)考试试卷:电商用户行为分析试题
- 2025年电梯安装维修人员考试试卷:电梯运行监测与数据分析真题汇编
- 2025年美发师(中级)美发行业数据分析考试试卷
- 上海虹口区2024-2025学年下学期七年级期末考试英语试题(含答案无听力原文及音频)
- 2024年江苏省徐州市保安员证考试题库及答案()
- 保洁学校管理制度
- 天台保安考试题及答案
- 招聘渠道ROI评估模型-洞察及研究
- 2025春季学期国开电大本科《人文英语4》一平台机考真题及答案(第六套)
- 第七单元1认识小数(课件)-三年级数学下册(人教版)
- 2025年河北省中考麒麟卷生物(二)及答案
- 2024年民族出版社招聘事业编制专业技术人员真题
- 2025年食品安全管理员考试试题及答案
- 2025-2030骨科植入器材产业市场深度分析及发展趋势与投资战略研究报告
评论
0/150
提交评论