




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
湖南农业大学信息科学技术学院学 生 实 验 报 告姓名: 年级专业班级 日期 年 月 日 成绩 课程名称数据结构实验名称利用栈的基本操作实现表达式的计算 实验类型验证 设计综合 创新【实验目的、要求】(1) 熟悉VC+的上机环境,掌握VC+语言的编程过程(2) 会定义栈的存储结构(3) 熟悉对栈的一些基本操作和具体的函数的定义和实现方法【实验内容】(1) 实现顺序栈的相关运算(在一个程序中实现顺序表的建立、查找、插入、删除和输入操作)(2) 利用栈的相关运算,编程实现一个表达式的计算【实验环境】(含主要设计设备、器材、软件等)运行VC+的电脑一台【实验步骤、过程】(含原理图、流程图、关键代码,或实验过程中的记录、数据等)代码#include Stack2.h /链式栈类,模板#include char* toPostfix(char *expstr) /将中缀表达式转换成后缀表达式 Stack2 s1; /创建空栈,数据元素类型为char char *poststr=new charstrlen(expstr)+1; char out; int i=0,j=0; while(expstri!=0) coutexpstri=0 & expstri=9 & expstri!=0) /遇见数字时,加入到后缀表达式 poststrj=expstri; i+; j+; poststrj= ; /数值之间以空格分隔 j+; break; poststrj=0; cout poststr=poststrt; couts1; while(!s1.isEmpty() poststrj=s1.pop(); j+; poststrj=0; /后缀表达式字符串加结束符 return poststr;int value(char *poststr) /计算后缀表达式的值 Stack2 s2; /创建空栈,数据元素类型为int char *p=poststr; int x,y,z=0; while(*p!=0) /逐个检查后缀表达式中的字符 cout*p=*p=0 & *p=9) /遇到数字字符 z=0; while(*p!= ) /字符串转化为数值 z=z*10+*p-0; p+; p+; s2.push(z); /z值入栈 else if(*p!= ) y=s2.pop(); /出栈两个值 x=s2.pop(); switch(*p) /根据运算符,计算结果 case +: z=x+y; break; case -: z=x-y; break; case *: z=x*y; break; case /: z=x/y; break; s2.push(z); /计算结果再次入栈 p+; couts2; return s2.pop();void main() char *expstr1 = 1+2*(3+4)-5; coutexpstr1=expstr1n; char *poststr1=toPostfix(expstr1); couttoPostfix=poststr1n; coutvalue=value(poststr1)n;【实验结果或总结】(对实验结果进行相应分析,或总结实验的心得体会,并提出实验的改进意见)程序运行结果:expstr1=1+2*(3+4)-5expstr0=1 poststr=1 链式栈: expstr1=+ poststr=1 链式栈: + expstr2=2 poststr=1 2 链式栈: + expstr3=* poststr=1 2 链式栈: * + expstr4=( poststr=1 2 链式栈: ( * + expstr5=3 poststr=1 2 3 链式栈: ( * + expstr6=+ poststr=1 2 3 链式栈: + ( * + expstr7=4 poststr=1 2 3 4 链式栈: + ( * + expstr8=) poststr=1 2 3 4 +链式栈: * + expstr9=- poststr=1 2 3 4 +*+链式栈: - expstr10=5 poststr=1 2 3 4 +*+5 链式栈: - toPostfix=1 2 3 4 +*+5 -*p=1 链式栈: 1 *p=2 链式栈: 2 1 *p=3 链式栈: 3 2 1 *p=4 链式栈: 4 3 2 1 *p=+
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025粮油食品检验人员模考模拟试题附答案详解【研优卷】
- 脑梗塞静脉取栓护理查房
- 2026届安徽省合肥市肥西县化学九年级第一学期期中质量跟踪监视试题含解析
- 内蒙古通辽市科尔沁左翼中学旗县2026届九年级英语第一学期期末达标检测试题含解析
- 义务均衡发展培训
- 广东省佛山禅城区七校联考2026届英语九上期末综合测试试题含解析
- 幼儿园指导纲要解读培训
- 2026届辽宁省沈阳市大东区化学九上期末学业水平测试模拟试题含解析
- 2026届安徽省砀山县化学九上期末调研模拟试题含解析
- 2026届北京六十六中学化学九年级第一学期期中学业质量监测模拟试题含解析
- 水域救援知识课件
- GB 31604.60-2024食品安全国家标准食品接触材料及制品溶剂残留量的测定
- 新国际政治学概论(第三版)-教学课件-陈岳-109503国际政治学概论(第三版)
- XX医院DRG绩效分配方案
- 《研究生英语》(第二版)练习答案及译文
- 加油船租赁油船租赁合同
- 《茶叶审评技术》课程考试复习题库(含答案)
- 专题四“挺膺担当”主题团课
- 智能高速铁路概论-课件-第一章-世界智能铁路发展-
- 部编人教版五年级上册语文 第三单元单元分析
- 空间向量及其运算练习题
评论
0/150
提交评论