- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
- 2011年全国中考政治试题分类汇编 专题十一 法律与社会秩序(200套真题+模拟) 人教新课标.doc
- 2012中考历史复习试题 第10单元 建设有中国特色的社会主义及民族团结与祖国统一(含11真题带解析) 人教新课标.doc
- 黑龙江哈九中2012届高三理综第四次模拟试题【会员独享.doc
- 2012中考历史专题复习试题 专题六 中外历史上的思想家及思想解放运动(含11真题带解析.doc
- 2012中考历史复习试题 第11单元 国防建设与外交成就、科技教育与文化和社会生活(含11真题带解析) 人教新课标.doc
- 2011年全国中考政治试题分类汇编 专题十四 坚持可持续发展战略(200套真题+模拟) 人教新课标.doc
- 2012中考历史复习试题 第16单元 两次世界大战之间的世界及二战爆发(含11真题带解析) 人教新课标.doc
- 2012中考历史复习试题 第15单元 垄断资本主义时代的世界与近代科技文化(含11真题带解析) 人教新课标.doc
- 2006-2011中考历史真题课课练 八年级上册 第9课 新文化运动 人教新课标.doc
- 2011年全国中考政治试题分类汇编 专题十五 建设中国特色社会主义文化(200套真题+模拟) 人教新课标.doc
最近下载
- 2022年浙江省公务员考试《申论》真题及参考答案.docx VIP
- 新疆交投集团招聘笔试真题2024.docx VIP
- 第5讲从垄断到金融垄断—当代资本主义的发展.ppt VIP
- GB50205-2020钢结构工程施工质量验收标准.docx VIP
- CPI-GEN-IV-速调管高功放教程.pdf VIP
- 最全100%必过地理信息安全保密培训证书题库(填空题).docx
- 2020最新-4S店配件价格-华晨宝马3系 F35(12-07--15-09).pdf VIP
- A Rose for Emily 原文.doc VIP
- 义务教育人教版信息科技三年级全一册教学设计教案.docx
- 2025年体育单招英语试卷 .pdf VIP
原创力文档


文档评论(0)