- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构课程设计栈和队列
实验课程名称 数据结构与课程设计
专 业 班 级 10级计科(2)班
学 生 姓 名 赵 腾 松
学 号 10410902044
指 导 教 师 冯 韵
2012 至 2013学年第 1 学期第 3 至 4 周
目录
1 概述 3
2 系统分析 3
3 概要分析 3
4 详细设计 3
4.1 中缀表达式转换为后缀表达式算法设计 3
4.2 后缀表达式算法设计 9
5 程序代码 10
6 运行与测试 14
7总结与心得 14
8 参考文献 14
1 概述
本次实验需要对栈和队列进行充分的了解虽然栈和队列实质上是不同的但在编写程序时大致相似。通常栈可以用顺序的方式存储分配一块连续的存储区域存放栈中元素并用一个变量指向当前的栈顶。而队列的顺序存储结构需要使用一个数组和两个整数型变量来实现。
2 系统分析
栈的顺序存储结构简称为顺序栈,它是运算受限的顺序表。对于顺序栈入栈时首先判断栈是否为满栈满的条件为p-top= =MAXNUM-1栈满时不能入栈; 否则出现空间溢出引起错误这种现象称为上溢。 出栈和读栈顶元素操作先判栈是否为空为空时不能操作否则产生错误。通常栈空作为一种控制转移的条件。
队列的顺序存储结构称为顺序队列顺序队列实际上是运算受限的顺序表。 入队时将新元素插入rear所指的位置然后将rear加1。出队时删去front所指的元素然后将front加1并返回被删元素。
3 概要分析
编写一个程序实现顺序栈的各种基本运算并在此基础上设计一个主程序完成如下功能:1初始化顺序栈;2插入元素;3删除栈顶元素;4取栈顶元素;5遍历顺序栈;6置空顺序栈。
编写一个程序实现顺序队列的各种基本运算并在此基础上设计一个主程序完成如下功能:1初始化队列;2建立顺序队列;3入队;4出队;5判断队列是否为空;6取队头元素;7遍历队列。
4 详细设计
4.1 中缀表达式转换为后缀表达式算法设计
顺序扫描中缀表达式,当读到数字时直接将其送至输出队列中;当读到运算符时,将栈中所有优先级高于或等于该运算符的运算符弹出,送至输出队列中,再将当前运算符入栈;当读到左括号时,即入栈;当读到右括号时,将靠近栈顶的第一个左括号上面的运算符全部依次弹出,送至输出队列,再删除栈中的左括号。
具体算法如下:
void CTPostExp(SeqQueue *Q)
{
SeqStack OS; //运算符栈
char c,t;
SeqStack *S;
S=OS; InitStack(S); //初始化栈
Push(S,#); //压入栈底元素#
do //扫描中缀表达式
{ c=getchar();
switch(c)
{
case :break; //去除空格符
case 0:
case 1:
case 2:
case 3:
case 4:
case 5:
case 6:
case 7:
case 8:
case 9:
EnQueue(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(c)=Priority(GetTop(S)))
{
t=Pop(S); EnQueue(Q,t);
}
Push(S,c); break;
}//EndSwitch
}while(c!=#);//以#号结束表达式扫描
}
要执行上述算法,还必须给出相关的栈和队列的定义、操作以及调用该算法的主函数。
具体算法如下:
#includestdio.h
#define StackSize 100
#define QueueSize 100
/*队列的相关操作*/
typedef char DataType;
typedef struct {
char data[100];
int front,rear;
}SeqQueue; //定义队列类型
void InitQueue(SeqQueue * Q)//初始化队列
{
Q-front=0; Q-rear=0;
}
int QueueEmpty(SeqQueue * Q) //判空队列
{
return Q-rear==Q-front;
}
void EnQueue(SeqQueue * Q, DataType x) //入队列
{
您可能关注的文档
- 多重共线性异方差的验证和修正-论文选读中国货币需求的因素分析.doc
- 多重复句和紧缩复句.doc
- 多重多元回归分析.doc
- 多重视角解读《呼兰河传》的女性悲剧.doc
- 多进制振幅调制解调.doc
- 多道程序缓冲区协调操作.doc
- 多重曝光和慢速摄影技巧.doc
- 多链路负载均衡的方案.doc
- 多重共线性处理.doc
- 多重启动光盘刻录.doc
- 人教版九年级上册数学精品教学课件 第24章 24.3 正多边形和圆 (3).ppt
- 北师版九年级上册数学精品教学课件 第5章 5.1投影.ppt
- 人教版九年级上册数学精品教学课件 练习册 第二十四章 圆 24.2 点和圆、直线和圆的位置关系-24.2.2 直线和圆的位置关系-第1课时 直线和圆的位置关系.ppt
- 人教版九年级上册数学精品教学课件 第二十四章 24.1.2 垂直于弦的直径 (2).ppt
- 人教版九年级上册数学精品教学课件 第24章 专项突破11 与圆的基本性质有关的辅助线的作法.ppt
- 北师版九年级上册数学精品教学课件 第4章 4.1成比例线段.ppt
- 人教版九年级上册数学精品教学课件 第23章 23.2.3 关于原点对称的点的坐标 (2).ppt
- 人教版九年级上册数学精品教学课件 第二十三章 23.2.2 中心对称图形.ppt
- 人教版九年级上册数学精品教学课件 练习册 第二十四章 圆 24.2 点和圆、直线和圆的位置关系-24.2.2 直线和圆的位置关系-第2课时 圆的切线的判定与性质.ppt
- 人教版九年级上册数学精品教学课件 第二十三章 测素质 图形的旋转及其应用.ppt
最近下载
- T∕CHCA 002-2024 热喷涂稀土合金复合涂层钢筋.pdf
- 建设工程工程量清单计价规范.docx VIP
- 第39讲建筑工程费用定额的适用范围及应用一bak.pdf VIP
- B3201_T 1211-2024 既有公共建筑能效提升节能量核定技术规程.pdf VIP
- 安全仪表系统检验测试计划.docx VIP
- 2025年义务教育2022年版《道德与法治课程标准》真题试卷附参考答案.docx VIP
- 智能安防巡逻机器人解决方案.doc VIP
- 常州站车站行车工作细则.pdf VIP
- 专用设备的操作手册编写与用户培训考核试卷.docx VIP
- 工程造价咨询服务方案 第二章 工作流程及进度控制方案.docx VIP
文档评论(0)