




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
本文格式为Word版,下载可任意编辑——数据结构栈和队列
试验二栈和队列
一、试验目的
1.把握栈的顺序表示和实现2.把握队列的链式表示和实现二、试验内容
1.编写一个程序实现顺序栈的各种基本运算。2.实现队列的链式表示和实现。三、试验步骤
1.初始化顺序栈2.插入元素3.删除栈顶元素4.取栈顶元素5.遍历顺序栈6.置空顺序栈7.初始化并建立链队列8.入链队列9.出链队列10.遍历链队列四、实现提醒
1./*定义顺序栈的存储结构*/typedefstruct{
ElemTypestack[MAXNUM];inttop;}SqStack;
/*初始化顺序栈函数*/voidInitStack(SqStack*p)
{q=(SqStack*)malloc(sizeof(SqStack)/*申请空间*/)/*入栈函数*/
voidPush(SqStack*p,ElemTypex)
{if(p->toptop=p->top+1;/*栈顶+1*/p->stack[p->top]=x;}/*数据入栈*/}
/*出栈函数*/
ElemTypePop(SqStack*p)
{x=p->stack[p->top];/*将栈顶元素赋给x*/p->top=p->top-1;}/*栈顶-1*//*获取栈顶元素函数*/ElemTypeGetTop(SqStack*p){x=p->stack[p->top];}/*遍历顺序栈函数*/voidOutStack(SqStack*p){for(i=p->top;i>=0;i--)
printf(\第%d个数据元素是:m\\n\/*置空顺序栈函数*/voidsetEmpty(SqStack*p){p->top=-1;}2./*定义链队列*/typedefstructQnode{ElemTypedata;structQnode*next;}Qnodetype;typedefstruct{Qnodetype*front;Qnodetype*rear;}Lqueue;
/*初始化并建立链队列函数*/voidcreat(Lqueue*q)
{h=(Qnodetype*)malloc(sizeof(Qnodetype));/*初始化申请空间*/h->next=NULL;q->front=h;q->rear=h;
for(i=1;idata=x;s->next=NULL;q->rear->next=s;q->rear=s;}/*出链队列函数*/
ElemTypeLdelete(Lqueue*q){p=q->front->next;q->front->next=p->next;if(p->next==NULL)q->rear=q->front;x=p->data;
free(p);}/*释放空间*//*遍历链队列函数*/voiddisplay(Lqueue*q)
{while(p!=NULL)/*利用条件判断是否到队尾*/{printf(\p=p->next;}}
五、思考与提高
1.读栈顶元素的算法与退栈顶元素的算法有何区别?
2.假使一个程序中要用到两个栈,为了不发生上溢错误,就必需给每个栈预先分派一个足够大的存储空间。若每个栈都预分派过大的存储空间,势必会造成系统空间紧张。如何解决这个问题?
(1)链栈只有一个top指针,对于链队列,为什么要设计一个头指针和一个尾指针?
(2)一个程序中假使要用到两个栈时,可通过两个栈共享一维数组来实现。即双向栈共享邻接空间。假使一个程序中要用到两个队列,能否实现?如何实现?
六、完整参考程序1.栈的顺序表示和实现
#include#include#include
#defineTRUE1#defineFALSE0#defineOK1#defineERROR0#defineINFEASIBLE-1#defineOVERFLOW-2
typedefintStatus;typedefintSElemType;
//栈的顺序存储表示#defineSTACK_INIT_SIZE100#defineSTACKINCREMENT10
typedefstruct{SElemType*base;SElemType*top;intstacksize;}SqStack;
StatusInitStack(SqStackStatusDestroyStack(SqStackStatusStackDisplay(SqStackStatusGetTop(SqStackS,SElemTypeStatusPush(SqStackStatusPop(SqStackStatusStackEmpty(SqStackS);
StatusInitStack(SqStackif(!S.base)exit(OVERFLOW);//存储分派失效S.top=S.base;
S.stacksize=STACK_INIT_SIZE;returnOK;
}//InitStack
StatusDestroyStack(SqStackS.top=S.base=NULL;returnOK;
}//InitStack
StatusStackDisplay(SqStack
inti=0;
if(S.base==S.top){printf(\堆栈已空!\\n\returnOK;}
while(p#include#include#defineTRUE1#defineFALSE0#defineOK1#defineERROR0#defineINFEASIBLE-1#defineOVERFLOW-2
//Status是函数的类型,其值是函数结果状态代码typedefintStatus;
//ElemType是顺序表数据元素类型,此程序定义为int型typedefintQElemType;
//单链队列--队列的链式存储结构typedefstructQNode{//定义结点结构
QElemTypedata;//数据域structQNode*next;//指针域
}QNode,*QueuePtr;
typedefstructlinkqueue{//定义队列结构
QueuePtrfront;//队头指针QueuePtrrear;//队尾指针
}LinkQueue;
StatusInitLinkQueue(LinkQueue//初始化一个队列StatusDestroyLinkQueue(LinkQueue//销毁一个队列intLinkQueueLength(LinkQueue//队列的长度StatusEnLinkQueue(LinkQueue//将一个元素入队列StatusDeLinkQueue(LinkQueue//将一个元素出队列StatusDisplayLinkQueue(LinkQueue);//显示队列中所有元素
voidmain(){
LinkQueueLQ;QElemTypee;intflag=1,ch,len;Statustemp;
printf(\本程序实现链式结构队列的操作。\\n\printf(\可以进行入队列、出队列等操作。\\n\InitLinkQueue(LQ);//初始化队列while(flag){
printf(\请选择:\\n\
printf(\显示队列所有元素\\n\printf(\入队列\\n\printf(\出队列\\n\printf(\求队列的长度\\n\printf(\退出程序\\n\scanf(\switch(ch){
}}
case1:DisplayLinkQueue(LQ);//显示队列中所有元素
break;
case2:printf(\请输入要人队的元素(一个整数):\
scanf(\//输入要入队列的字符EnLinkQueue(LQ,e);//入队列DisplayLinkQueue(LQ);break;
case3:temp=DeLinkQueue(LQ,e);//出队列
if(temp==OK){}
elseprintf(\队列为空!\\n\break;
printf(\出队一个元素:%d\\n\DisplayLinkQueue(LQ);
case4:len=LinkQueueLength(LQ);
printf(\队列的长度为:%d\\n\break;
default:flag=0;}
printf(\程序运行终止,按任意键退出!\\n\getch();
StatusInitLinkQueue(LinkQueue//生成一个头结点,并
把首尾指针指向头结点
}
Q.front->next=NULL;returnOK;
StatusDestroyLinkQueue(LinkQueue
p=(QueuePtr)malloc(sizeof(QNode));//生成一个新结点p->data=e;//赋值p->next=NULL;
Q.rear->next=p;//插入至队列尾Q.rear=p;//修改队尾指针returnOK;inti=0;
QueuePtrp=Q.front;while(p!=Q.rear){}returni;
++i;p=p->next;QueuePtrp;QElemTypee;while(Q.front!=Q.rear)
DeLinkQueue(Q,e);
free(Q.front);Q.front=Q.rear=NULL;returnOK;
StatusDeLinkQueue(LinkQueue
if(Q.front==Q.rear)returnERROR;//判断队列是否已空,已空返回
p=Q.front->next;//p指向队列中第一个元素e=p->data;//取得该元素值Q.front->next=p->next;//修改队首指针
if(Q
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 绩效管理和激励计划
- 班级自主管理的实施案例研究计划
- 2025年中国消毒灭菌设备行业市场运行态势、进出口贸易及发展趋势预测报告
- 企业战略规划与执行结构优化方案
- 电子支付系统安全测试的要点
- 2025年农林牧渔专用仪器仪表项目建议书
- 2025年NOX、NO2自动采样器及测定仪合作协议书
- 新产品使用指南及功能介绍
- 物理治疗课件
- 80天环游地球知识竞赛
- 不需公证的遗嘱范文
- 实验动物与动物福利
- 2024年成都新都投资集团有限公司招聘笔试冲刺题(带答案解析)
- 危险预知训练表(KYT)
- 2024年湖南铁路科技职业技术学院单招职业技能测试题库及答案解析
- 《书籍装帧设计》 课件 项目1 走进书籍装帧设计
- (正式版)SHT 3115-2024 石油化工管式炉轻质浇注料衬里工程技术规范
- (正式版)JBT 9630.1-2024 汽轮机铸钢件无损检测 第1部分:磁粉检测
- ASTM标准全部目录(中文版)
- 地震应急救援培训课件
- 《汽车电气设备构造与维修》 第4版 课件 第3、4章 电源系统、发动机电器
评论
0/150
提交评论