




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 循环队列的学习解析以及C语言实现首先我们先来了解一下队列的概念:队列是一种先进先出的线性表只能在表头删除在表尾插入,操作系统的作业队列就是队列的一个很好的应用。也有可以在两端均可进行插入和删除操作的队列,称为双端队列,但其用处并没有一般队列广泛。ADT Queue 数据对象: Dai | aiElemSet, i=1,2,.,n, n0 数据关系: R1 <a i-1,ai > | ai-1, ai D, i=2,.,n (约定其中a1 端为队列头, an 端为队列尾)基本操作 : InitQueue(&Q) 初始化队列 DestroyQueue(&Q) 销毁队列
2、 QueueEmpty(Q) 判断队列空否 QueueLength(Q) 求取队长 GetHead(Q, &e) 取对头元素 ClearQueue(&Q) 清空对列 EnQueue(&Q, e) 入队一个元素 DeQueue(&Q, &e) 出队一个元素 QueueTravers(Q, visit()) 访问队列 ADT Queue 队列也有两种存储结构,分别是顺序存储和链式存储。队列的顺序结构和顺序表以及顺序栈的存储结构类似,他们所运用的都是一组地址连续的存储。其中队列需要附设两个整形变量front和rear分别指示队列头元素和队列的尾元素的位置。cb
3、a54Q.rear321Q.frontQ.frontQ.rear0 (1)空队列 (2)a,b,c相继入队 由于顺序队列所分配的空间有限,根据队列入队和出队的特点可能发生“假溢出”现象,即队尾元素无法在前移。解决的办法就是将队列抽象成为环状,即循环队列。队空条件:Q.front=Q.rear 队满条件:(Q.rear+1)%MAXQSIZE循环队列以下是循环队列的几种主要的操作以及C语言实现:/*循环队列的数据结构*/#define MAXQSIZE10 typedef struct QElemType *base; int front; int rear; SqQueue;1、 循环队列的初
4、始化 Status InitQueue(SqQueue &Q) /构建一个空队列 Q.base = new QElemTypeMAXQSIZE; if( Q.base = NULL) /存储分配失败 exit(OVERFLOW) ; Q.front = Q.rear = 0; /头尾指针置为零,队列为空 return OK;2、 求循环队列长度 int QueueLength(Squeue Q) return (Q.rear - Q.front + MAXQSIZE )%MAXQSIZE; 3、 入队 Status EnQueue (SqQueue &Q , QElemType
5、 e) if(Q.rear+1)%MAXQSIZe = Q.front)return ERROW;Q.baseQ.rear = e;Q.rear = (Q.rear + 1) %MAXQSIZE; return OK: 4、 出队 Status DeQueue(SqQueue &Q,QElemType &e) if(Q.front=Q.rear)return ERROW;e=Q.baseQ.front; Q.front = (Q.front + 1 )%MAXQSIZE; return OK; 5、 取队头元素 SElemType GetHead(SqQueue Q) if(Q
6、.front ! = Q.rear) return Q.baseQ.front; 队列的链式表示和实现。/*队列的链式存储结构*/typedef struct QNondeQElemType date;struct QNode *next; QNode,QueuePtr; typedef struct QueuePtr front; QueuePtr rear; LinkQueue;1、 初始化 Status InitQueue(LinkQueue &Q)Q.front = Q.rear = new QNode;Q>front -> next = NULL;return O
7、K; 2、 入队Status EnQueue(LinkQueue &Q,QElemType e)p = new QNode ;p -> date = e;p -> next = NULL;Q.rear -> next = p;Q.rear = p;return OK;3、 出队Status Dequeue(LinkQueue &Q,QElemType &e)if(Q.front = Q.rear)return ERROR; e = p -> date; Q.front -> next = p -> next; if(Q.rear = p) Q.rear = Q.front; delete
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 湖北省十堰市2024-2025学年高三下学期四月调研考试数学试题
- 广西玉林市本年度(2025)小学一年级数学部编版随堂测试((上下)学期)试卷及答案
- 新疆吐鲁番地区本年度(2025)小学一年级数学统编版课后作业((上下)学期)试卷及答案
- 大学生如何制定合理有效的学习计划书
- 2025春季学期国家开放大学专科《建筑工程计量与计价》一平台在线形考(作业1至4)试题及答案
- 人工智能核心算法模拟题(附参考答案)
- 职业技术学校软件与信息服务专业人才培养方案(2024年)
- 2025年山西省晋中市平遥县中考一模历史试题(原卷版+解析版)
- 河南省许昌市部分校2024-2025学年高一下学期4月期中考试数学试题(原卷版+解析版)
- 畜牧养殖技术培训与职业技能提升项目的开展考核试卷
- 学校结核病疫情调查与应急处置1
- 老人接种疫苗科普知识讲座
- 科学方法和实验设计
- 经肛型肠梗阻导管
- 成圈机操作规程
- 加油站安全生产责任制
- 万千心理情绪障碍跨诊断治疗的统一方案:治疗师指南
- 道路建设项目实施方案范文(五篇)
- 2023年韶关市始兴县事业单位真题
- 矿井有计划停电停风通风安全技术措施
- 《卫生事业管理学》练习考试题库(100题)
评论
0/150
提交评论