数据结构栈和队列应用表达式求值.pdf
《数据结构栈和队列应用表达式求值.pdf》由会员分享,可在线阅读,更多相关《数据结构栈和队列应用表达式求值.pdf(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、2018-2018 学年第一学期 数据结构课内实验报告 实验名:栈和队列的应用:表达式的求值 姓名:学号:班级:指导老师:日期:实验题目:1、实验目的:通过此实验进一步理解栈和队列,提高运用理论解决实际问题的能力。2、实验内容:例如,输入9-2+4*7)/5+3#,并按回车键,即可输出结果如下:表达式的运算结果是:6 表达式的后缀表达式为:9 2 4 7*+5/-3+3、数据结构及算法思想:表达式计算是实现程序设计逻辑语言的基本问题之一,也是栈和队列应用的一 个典型的例子。该设计是先通过栈将中缀表达式转换为后缀表达式,在转换过 程中又用到了队列的操作。而在得到后缀表达式之后,又用到队列的操作对
2、生 成的后缀表达式进行计算。在整个设计的实现过程中,用到的都是栈和队列的 概念。b5E2RGbCAP 4、模块化分:本程序分为2个模块:1)中缀表达式转换为后缀表达式;中缀表达式转换为后缀表达式 void CTPostExp(SeqQueue*Q case 6:SeqStack S char c,t。In itStack(&S。Push(&S,#。运算符栈/初始化栈 压入栈底元素#case 1:do 扫描中缀表达式 c=getchar(。switch(c case case 0:case 2 case 3 case 4 case 5 去除空格符 case 7:case 8:case 9:EnQ
3、ueue(Q,c break。case(:Push(&S,c break。case:case#:do t=Pop(&S。if(t!=(&t!=#EnQueue(Q,t。while(t!=(&S.top!=-1。break。case+:case-:case*:case/:while(Priority(cv=Priority(GetTop(S t=Pop(&S。EnQueue(Q,t。Push(&S,c。breako while(c!=#。以#号结束表达式扫描 (2后缀表达式的计算 DataType CPostExp(SeqQueue Q SeqStack S char ch。int x,y。In
4、 itStack(&S。while(!QueueEmpty(Q ch=DeQueue(&Q。if(ch=0&ch Push(&S,ch。else y=Pop(&S-0。x=Pop(&S-0。switch(ch case+:Push(&S,(char(x+y+0。break。case-:Push(&S,(char(x-y+0)break。case*:Push(&S,(char(x*y+0。break。case 7:Push(&S,(char(x/y+0。break。return GetTop(S。输入9-2+4*7)/5+3#,并按回车键,输出:表达式的运算结果是:6 表达式的后缀表达式为:9
5、2 4 7*+5/-3 6、调试情况,设计技巧及体会:表达式是由运算对象、运算符、括号组成的有意义的式子。要写此程 序,必须了解到底什么是中缀表达式、后缀表达式并灵活运用栈和队 列o plEanqFDPw 7、源程序清单:#in clude#define StackSize 100#define QueueSize 100/*队列的相关操作*/typedef char DataType。typedef struct char data100。int fron t,rear。SeqQueue。/定义队列类型 void Ini tQueue(SeqQueue*Q 初始化队列 Q-fro nt=0。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 队列 应用 表达式 求值
限制150内