chapter4 队列.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第四章:队列( queue ) 4.1 概念 4.2 队列的顺序存储结构 4.3 循环队列 4.4 链队列 4.5 队列应用 4.1 概念 定义和特点 定义:队列是限定只能在表的一端进行插入,在表的另一端进行删除的线性表。 队尾(rear)——允许插入的一端。 队头(front)——允许删除的一端。 队列特点:先进先出(FIFO) 4.2队列的顺序存储结构 解决方案 4.3 循环队列 队满、队空判定条件 循环队列类型定义 入队 出队 求循环队列的长度 4.4 链队列 基本操作 算法实现 4.5 队列应用 队列应用举例——划分子集问题 算法思想:利用循环筛选。从第一个元素开始,凡与第一个元素无冲突的元素划归一组;再将剩下的元素重新找出互不冲突的划归第二组;直到所有元素进组。 所用数据结构 冲突关系矩阵 r[i][j]=1, i,j有冲突 r[i][j]=0, i,j无冲突 循环队列cq[n]; 数组group[n]存放每个元素的分组号,如group[3]=5表示第3个元素的分组号为5; 工作数组clash[n]:记录和当前已入组元素发生冲突的元素的信息。如clash[2]=1,表示第2个元素与当前已入组元素发生冲突。 工作过程 初始状态:A中元素放于cq中,group和clash数组清零,组号group=1 第一个元素出队,将r矩阵中第一行“1”拷入clash中对应位置,这样,凡与第一个元素有冲突的元素在clash中对应位置处均为“1”,下一个元素出队 若其在clash中对应位置为“1”,有冲突,重新插入cq队尾,参加下一次分组 若其在clash中对应位置为“0”, 无冲突,可划归本组;再将r矩阵中该元素对应行中的“1”拷入clash中 如此反复,直到9个元素依次出队,由clash中为“0”的单元对应的元素构成第1组,将组号group值“1”写入group对应单元中 令group=2,clash清零,对cq中元素重复上述操作,直到cq中front==rear,即队空,运算结束 = = LOGO a1 a2 a3…………………….an 入队 出队 front rear 队列Q=(a1,a2,……,an) front=-1 rear=-1 1 2 3 4 5 0 队空 1 2 3 4 5 0 front a,b,c入队 a b c rear rear 1 2 3 4 5 0 d,e,f入队 d e f front 设两个指针front,rear,约定: rear指示队尾元素; front指示队头元素前一位置 初值front=rear=-1 空队列条件:front==rear 入队列:Q[++rear]=x; 出队列:x=Q[++front]; rear rear front rear 1 2 3 4 5 0 a,b,c出队 a b c front front front 实现:用一维数组实现Q[M] rear 1 2 3 4 5 0 d e f Front=-1 a b c 真溢出 存在问题 设数组维数为M,则: 当front=-1,rear=M-1时,再有元素入队发生溢出—真溢出 当front?-1,rear=M-1时,再有元素入队发生溢出—假溢出 rear 1 2 3 4 5 0 d e f front 假溢出 方案1:队首固定,每次出队剩余元素向下移动——浪费时间。 方案2:循环队列 基本思想:把队列设想成环形,让Q[0]接在Q[M-1]之后,若rear+1==M,则令rear=0。 front rear d e f 0 1 2 3 4 … M-1 rear 1 2 3 4 0 d e f front … M-1 实现:利用“模”运算 入队: rear=(rear+1)%M; Q[rear]=x; 出队: front=(front+1)%M; x=Q[front]; rear front 0 1 2 3 4 5 a4 a5 a6 0 1 2 3 4 5 rear front a9 a8 a7 a4 a5 a6 0 1 2 3 4 5 rear front 初始状态 a4,a5,a6出队 a7,a8,a9入队 队空:front= =rear 队满:front= =rear 解决方案: 1.另外设一个标志以区别队空、队满: int flag; if(front==rear “出现在入队操作之后 ”) flag=1; //队满 else if(front==rear “出现在出队操作之后 ”) flag=0; //队空 2. 少用一个元素空间: 队空:front==rear 队满:(rear+1)%M= =front a4 a5 a6 0 1

您可能关注的文档

文档评论(0)

sm8558 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档