- 1、本文档共36页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
思考题 * 数据结构 * 3.4 队列 3.4.1 抽象数据类型队列的定义 队列(Queue):一种运算受限的线性表。只允许在表的一端进行插入,而在另一端进行删除。允许删除的一端称为队头(front),允许插入的一端称为队尾(rear)。 先进入队列的成员总是先离开队列。故队列亦称先进先出(First In First Out)的线性表,简称FIFO表。 (a1, a2, ……, an) 队尾 队头 下图是队列的示意图: 队列的抽象数据定义见书P59 除了栈和队列之外,还有一种限定性数据结构,它们是双端队列 a1 a2 a3 入队 队尾 队头 出队 队头 端1 端2 插入 删除 ? ? 双端队列示意图 a1 a2 ai a0 an-1 删除 插入 ? ? … … 3.4.2 链队列—队列的链式表示和实现 队列的链式存储结构简称为链队列,它是限制仅在表头删除和表尾插入的单链表。显然仅有单链表的头指针不便于在表尾做插入操作,为此再增加一个尾指针,指向链表的最后一个结点。 rear front ∧ … ∧ front rear 非空队 rear front a1 an ∧ … a2 Q rear front Q a1 ∧ rear front Q ∧ 空队 只有一个元素结点 头尾指针封装在一起的链队 front rear x入队 ^ x front rear y入队 x ^ y front rear x出队 x ^ y front rear y出队 ^ typedef struct QNode{ QElemType data; QNode *next; } QNode ,*QueuePtr; typedef struct { QueuePtr front,rear; // 队头、队尾指针 } LinkQueue; Status InitQueue(LinkQueue Q) { // 构造一个空队列Q if(!(Q.front=Q.rear=(QueuePtr)malloc(sizeof(QNode)))) exit(OVERFLOW); Q.front-next=NULL; return OK; } front rear 空队 ^ Status DestroyQueue(LinkQueue Q) { // 销毁队列Q(无论空否均可) while(Q.front){ Q.rear=Q.front-next; free(Q.front); Q.front=Q.rear; } return OK; } Status EnQueue(LinkQueue Q,QElemType e) { // 插入元素e为Q的新的队尾元素 if(!(p=(QueuePtr)malloc(sizeof(QNode))))//失败 exit(OVERFLOW); p-data=e; p-next=NULL;Q.rear-next=p; Q.rear=p; return OK; } p front a2 an ∧ rear ∧ rear a1 e Status DeQueue(LinkQueue Q,QElemType e) { // 若队列不空,删除Q的队头元素,用e返回其值,并返回OK,否则返回ERROR if(Q.front==Q.rear) return ERROR; p=Q.front-next; e=p-data; Q.front-next=p-next; if(Q.rear==p) Q.rear=Q.front; free(p); return OK; } front a1 a2 an ∧ rear p front a1 p ∧ rear ∧ rear 3.4.3 循环队列-队列的顺序表示和实现 初始空队列:front = rear=0 ; 插入新的元素时, rear++; 删除队头元素时,front++; 0 1 2 3 4 入队 出队 a3 a4 Q.rear Q.front a5 Q.rear 假溢出 如何解决假溢出? Q.rear a6 Q.rear 1 0 maxsize-1 ... Q.front Q.rear ... 队列 当Q.rear Q.front时: Q.rear – Q.fr
您可能关注的文档
最近下载
- 2023年全国硕士研究生入学统一考试英语(二)试题.doc
- coc七版半自动人物卡v1.8.9 .xlsx VIP
- 2025会计考试题库及答案(通用6篇) .pdf VIP
- 2024年湖南省益阳市高职单招综合素质考试试题及答案解析.docx
- 小学六年级下册数学 期末测试卷及答案.docx
- 2024年芜湖职业技术学院单招职业适应性测试试题库 带答案(实用).docx
- 2024年中级注册安全工程师《专业实务-建筑施工安全》真题及答案解析.pdf
- 乌鲁木齐地区2025年高三年级第一次质量监测(一模)物理试卷(含官方答案).pdf
- 2014款上汽大众途观_汽车使用手册用户操作图示图解详解驾驶指南车主车辆说明书电子版.pdf
- 秋叶 - COC七版半自动人物卡v2.0.1(通用)(2022年-2023年).pdf VIP
文档评论(0)