![數(shù)據(jù)結(jié)構(gòu)課件版章隊(duì)列_第1頁](http://file4.renrendoc.com/view11/M01/02/09/wKhkGWWwEB6AZUJIAAErWpnBvlY759.jpg)
![數(shù)據(jù)結(jié)構(gòu)課件版章隊(duì)列_第2頁](http://file4.renrendoc.com/view11/M01/02/09/wKhkGWWwEB6AZUJIAAErWpnBvlY7592.jpg)
![數(shù)據(jù)結(jié)構(gòu)課件版章隊(duì)列_第3頁](http://file4.renrendoc.com/view11/M01/02/09/wKhkGWWwEB6AZUJIAAErWpnBvlY7593.jpg)
![數(shù)據(jù)結(jié)構(gòu)課件版章隊(duì)列_第4頁](http://file4.renrendoc.com/view11/M01/02/09/wKhkGWWwEB6AZUJIAAErWpnBvlY7594.jpg)
![數(shù)據(jù)結(jié)構(gòu)課件版章隊(duì)列_第5頁](http://file4.renrendoc.com/view11/M01/02/09/wKhkGWWwEB6AZUJIAAErWpnBvlY7595.jpg)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院1第4章隊(duì)列4.0BusStopQueue4.1ADT隊(duì)列4.2用指針實(shí)現(xiàn)ADT隊(duì)列4.3用循環(huán)數(shù)組實(shí)現(xiàn)ADT隊(duì)列4.4ADT隊(duì)列的應(yīng)用——電路布線問題4.5ADT隊(duì)列的其它應(yīng)用舉例吳英杰2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院24.0BusStopQueueBusStopfrontrearrearrearrearrear2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院34.0BusStopQueueBusStopfrontrearrearrear2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院44.0BusStopQueueBusStopfrontrearrear2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院54.0BusStopQueueBusStopfrontrearrear返回章目錄2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院6隊(duì)列是一種特殊的線性表,是操作受限的線性表,稱其為限定性數(shù)據(jù)結(jié)構(gòu)。隊(duì)列的定義及特點(diǎn)定義:隊(duì)列是限定只能在表的一端進(jìn)行插入,在表的另一端進(jìn)行刪除的線性表隊(duì)尾(rear)——允許插入的一端隊(duì)頭(front)——允許刪除的一端隊(duì)列特點(diǎn):先進(jìn)先出(FIFO)4.1ADT隊(duì)列(Queue)2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院7a1a2a3…….an入隊(duì)出隊(duì)frontrear隊(duì)列Q=(a1,a2,……,an)雙端隊(duì)列a1a2a3…….an端1端2入隊(duì)出隊(duì)入隊(duì)出隊(duì)2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院84.1ADT隊(duì)列(Queue)ADT隊(duì)列上定義的常用的基本運(yùn)算QueueEmpty(Q):QueueFull(Q):QueueFirst(Q):(4)QueueLast(Q):(5)EnterQueue(x,Q):(6)DeleteQueue(Q):
返回章目錄2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院9鏈隊(duì)列結(jié)點(diǎn)定義4.2用指針實(shí)現(xiàn)ADT隊(duì)列typedefstructqnode*qlink;typedefstructqnode{QItemelement;qlinknext;}Qnode;2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院10用指針實(shí)現(xiàn)的隊(duì)列Queue的定義typedefstructlque*Queue;typedefstructlque{qlinkfront;//隊(duì)首結(jié)點(diǎn)指針
qlinkrear;//隊(duì)尾結(jié)點(diǎn)指針}Lqueue;2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院11frontrearx入隊(duì)^xfrontrear空隊(duì)列^^frontyz入隊(duì)xyrear^zfrontrearx出隊(duì)y^zx2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院12入隊(duì)算法voidEnterQueue(QItemx,QueueQ){qlinkp;p=NewQNode();/*創(chuàng)建一個(gè)新結(jié)點(diǎn)*/p->element=x;p->next=0;/*在隊(duì)尾插入新結(jié)點(diǎn)*/if(Q->front)Q->rear->next=p;/*隊(duì)列非空*/elseQ->front=p;/*空隊(duì)列*/Q->rear=p;}2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院13出隊(duì)算法返回章目錄QItemDeleteQueue(QueueQ){qlinkp;QItemx;if(QueueEmpty(Q))Error(“Queueisempty”);x=Q->front->element;p=Q->front;Q->front=Q->front->next;free(p);returnx;}2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院144.3用循環(huán)數(shù)組實(shí)現(xiàn)ADT隊(duì)列1、先考慮用一維數(shù)組sq[M]實(shí)現(xiàn)ADT隊(duì)列front=-1rear=-1123450隊(duì)空123450frontJ1,J2,J3入隊(duì)J1J2J3rearrear123450J4,J5,J6入隊(duì)J4J5J6front設(shè)兩個(gè)指針front,rear,約定:rear指示隊(duì)尾元素;front指示隊(duì)頭元素前一位置初值front=rear=-1空隊(duì)列條件:front==rear入隊(duì)列:sq[++rear]=x;出隊(duì)列:x=sq[++front];rearrearfrontrear123450J1,J2,J3出隊(duì)J1J2J3frontfrontfront2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院15存在問題設(shè)數(shù)組維數(shù)為M,則:當(dāng)front=-1,rear=M-1時(shí),再有元素入隊(duì)發(fā)生溢出——溢出當(dāng)front-1,rear=M-1時(shí),再有元素入隊(duì)發(fā)生溢出——假溢出解決方案隊(duì)首固定,每次出隊(duì)剩余元素向下移動(dòng)——浪費(fèi)時(shí)間循環(huán)隊(duì)列基本思想:把隊(duì)列設(shè)想成環(huán)形,讓sq[0]接在sq[M-1]之后,若rear+1==M,則令rear=0;0M-11frontrear…...…...實(shí)現(xiàn):利用“模”運(yùn)算入隊(duì):rear=(rear+1)%M;sq[rear]=x;出隊(duì):front=(front+1)%M;x=sq[front];隊(duì)滿、隊(duì)空判定條件2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院16012345rearfrontJ4J5J6012345rearfrontJ9J8J7J4J5J6012345rearfront初始狀態(tài)J4,J5,J6出隊(duì)
J7,J8,J9入隊(duì)
隊(duì)空:front==rear隊(duì)滿:front==rear解決方案:1.另外設(shè)一個(gè)標(biāo)志以區(qū)別隊(duì)空、隊(duì)滿2.少用一個(gè)元素空間:隊(duì)空:front==rear
隊(duì)滿:(rear+1)%M==front2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院172、用循環(huán)數(shù)組實(shí)現(xiàn)隊(duì)列用循環(huán)數(shù)組實(shí)現(xiàn)的隊(duì)列的特征數(shù)據(jù)及其類型隊(duì)列元素的類型:QItem循環(huán)數(shù)組的規(guī)模:MaxSize存放隊(duì)列的循環(huán)數(shù)組:QItem*queue;一個(gè)分量放一個(gè)元素;約定沿著隊(duì)列從首到尾的走向是順時(shí)針的。
指示隊(duì)首元素的前一個(gè)位置的下標(biāo):front;指示隊(duì)尾元素位置的下標(biāo):rear;約定:front=rear時(shí)為空隊(duì)列,(rear+1)%MaxSize=front
時(shí)為滿隊(duì)列。2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院18用循環(huán)數(shù)組實(shí)現(xiàn)的隊(duì)列Queue的定義typedefstructaque*Queue;typedefstructaque{intmaxsize;//循環(huán)數(shù)組大小intfront;//隊(duì)首游標(biāo)
intrear;//隊(duì)尾游標(biāo)
QItemqueue;//循環(huán)數(shù)組}Aqueue;2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院19入隊(duì)算法:出隊(duì)算法:返回章目錄voidEnterQueue(QItemx,QueueQ){if(QueueFull(Q))Error(“Queueisfull”);Q->rear=(Q->rear+1)%Q->maxSize;Q->queue[Q->rear]=x;}QItemDeleteQueue(QueueQ){if(QueueEmpty(Q))Error(“Queueisempty”);Q->front=(Q->front+1)%Q->maxSize;returnQ->queue[Q->front];}4.4ADT隊(duì)列的應(yīng)用—電路布線問題2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院21電路布線問題startpinendpinLabelallreachablesquares1unitfromstart.2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院22電路布線問題startpinendpinLabelallreachableunlabeledsquares2unitsfromstart.112024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院23電路布線問題startpinendpinLabelallreachableunlabeledsquares3unitsfromstart.11222222024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院24電路布線問題startpinendpinLabelallreachableunlabeledsquares4unitsfromstart.112222233332024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院25電路布線問題startpinendpinLabelallreachableunlabeledsquares5unitsfromstart.11222223333444442024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院26電路布線問題startpinendpinLabelallreachableunlabeledsquares6unitsfromstart.11222223333444445555552024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院27電路布線問題startpinendpinEndpinreached.Traceback.1122222333344444555555666666662024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院28電路布線問題startpinendpin4Endpinreached.Traceback.1122222333344444555555666666663521返回章目錄2024/1/24福州大學(xué)數(shù)學(xué)與計(jì)算機(jī)科學(xué)學(xué)院294.5隊(duì)列其它應(yīng)用舉例劃分子集問題 問題描述:已知集合A={a1,a2,……an},及集合上的關(guān)系R={(ai,aj)|ai,ajA,ij},其中(ai,aj)表示ai與aj間存在沖突關(guān)系。要求將A劃分成互不相交的子集A1,A2,……Ak,(kn),使任何子集中的元素均無沖突關(guān)系,同時(shí)要求分子集個(gè)數(shù)盡可能少例A={1,2,3,4,5,6,7,8,9}R={(2,8),(9,4),(2,9),(2,1),(2,5),(6,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 現(xiàn)代交通樞紐的鐵路貨運(yùn)效率優(yōu)化
- 深度解讀如何用云計(jì)算構(gòu)建高效智能制造平臺(tái)
- 國慶節(jié)巡航摩旅活動(dòng)方案
- 小學(xué)趣味運(yùn)動(dòng)會(huì)活動(dòng)方案策劃
- 2024年春七年級(jí)地理下冊 第九章 第二節(jié) 巴西說課稿 (新版)新人教版
- 23 梅蘭芳蓄須說課稿-2024-2025學(xué)年四年級(jí)上冊語文統(tǒng)編版001
- 8 千年夢圓在今朝(說課稿)2023-2024學(xué)年部編版語文四年級(jí)下冊
- 5 協(xié)商決定班級(jí)事務(wù) 說課稿-2024-2025學(xué)年道德與法治五年級(jí)上冊統(tǒng)編版
- 2023八年級(jí)英語上冊 Module 9 Population Unit 3 Language in use說課稿(新版)外研版
- 《10天然材料和人造材料》說課稿-2023-2024學(xué)年科學(xué)三年級(jí)下冊青島版
- 煤場用車輛倒運(yùn)煤的方案
- 《預(yù)防犯罪》課件
- 【企業(yè)作業(yè)成本在上海汽車集團(tuán)中的應(yīng)用研究案例7300字(論文)】
- 《民航服務(wù)溝通技巧》教案第6課巧妙化解沖突
- 化學(xué)用語專項(xiàng)訓(xùn)練
- 《了凡四訓(xùn)》課件
- 醫(yī)院住院病人健康教育表
- 風(fēng)險(xiǎn)矩陣法(詳細(xì))
- 實(shí)驗(yàn)室供應(yīng)商評(píng)價(jià)的5個(gè)基本步驟
- 電力公司工程勘察設(shè)計(jì)管理辦法
評(píng)論
0/150
提交評(píng)論