版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領
文檔簡介
1、棧和隊列,棧的定義和基本運算/ 順序棧/ 鏈棧/ 隊列的定義和基本運算/順序隊列/鏈式隊列/實訓,唐懿芳,數(shù)據(jù)結(jié)構(gòu)與算法,,目錄,CONTENTS,,,棧的定義和基本運算,1、棧的定義 2、棧的基本運算,01,數(shù)據(jù)結(jié)構(gòu)與算法,第一節(jié):棧的定義和基本運算,數(shù)據(jù)結(jié)構(gòu)與運算,生活中的棧與隊列棧和隊列是特殊的線性表棧與隊列的特征LIFO(Last In First Out)FIFO(First In First Out),棧
2、的定義,堆棧簡稱為棧,是限定只能在表的一端進行插入和刪除操作的線性表。在表中,允許插入和刪除的一端稱作“棧頂”,另一端稱作“棧底”。通常將元素插入棧頂?shù)牟俜Q作為“入?!保ㄟM?;驂簵#?,稱刪除棧頂元素的操作為“出?!?棧底,棧頂,入棧,出棧,圖3.1 堆棧,,,,,a1,a2,an,…,,,第一節(jié):棧的定義和基本運算,棧的基本運算,堆棧的基本運算如下。(1)StackInit()初始化堆棧。(2)StackEmpty(s) 判
3、定棧s是否為空。(3)StackLength(s) 求堆棧s的長度。(4)GetTop(s) 獲取棧頂元素的值。(5)Push(s, e) 將元素e進棧。(6)Pop(s),出棧(刪除棧頂元素)。,數(shù)據(jù)結(jié)構(gòu)與運算,第一節(jié):棧的定義和基本運算,棧的存儲結(jié)構(gòu),兩種存儲結(jié)構(gòu):(1)順序?!捎庙樞蚪Y(jié)構(gòu)存儲(2)鏈?!捎面準浇Y(jié)構(gòu)存儲,數(shù)據(jù)結(jié)構(gòu)與運算,,,順序棧,1、順序棧的存儲結(jié)構(gòu) 3、順序棧的案例2、順序棧的
4、基本運算,02,數(shù)據(jù)結(jié)構(gòu)與算法,第二節(jié):順序棧,順序棧的存儲結(jié)構(gòu),,MaxSize-1,#define MaxSize 堆棧可能達到的最大長度typedef struct { ElementType elem[MaxSize]; int top; /*棧頂位置*/} SeqStack;,棧底,棧頂,,,,,a0,a1,an-1,…,,備用空間,棧滿和??盏臈l件是什么?,棧滿:top=Maxsize-1??眨簍
5、op=-1,數(shù)據(jù)結(jié)構(gòu)與運算,,SeqStack StackInit(){ SeqStack s;s.top=-1; return(s);},,順序棧的基本運算,,初始化堆棧 StackInit(),,,int StackEmpty(SeqStack s){ return(s.top==-1);},,判定棧s是否為空StackEmpty(s),,,int StackLength(SeqStack s){retu
6、rn(s.top+1);},,求堆棧s的長度StackLength(s),,,ElementType GetTop(SeqStack s){ if (StackEmpty(s)) /*空棧*/return(nil); return(s.elem[s.top]);},,獲取棧頂元素的值GetTop(s),,,void Push(SeqStack *s, ElementType e){ if (s->
7、;top== MaxSize-1) /*棧滿*/printf(“Full”); else { s->top++; s->elem[s->top]=e ; }},,進棧Push(s, e),,,ElementType Pop(SeqStack *s){ if (s->top== -1) /*???/return(nil); /* 返回空值*/ e
8、lse { e=s->elem[s->top]; s->top--; return (e); }},,出棧Pop(s),,第二節(jié):順序棧,數(shù)據(jù)結(jié)構(gòu)與運算,順序棧案例1,【例1】假設有兩個棧共享一個一維數(shù)組空間[0,MaxSize-1],其中一個棧用數(shù)組的第0單元(元素)作為棧底,另一棧用數(shù)組的第MaxSize-1號單元(元素)作為棧底(即兩個堆棧從兩端向中間延伸),其對應的類型描述如下:#
9、define MaxSize 堆棧可能達到的最大長度typedef struct { ElementType elem[MaxSize]; int top1, top2; /*棧頂位置*/} ShareStack;,第二節(jié):順序棧,數(shù)據(jù)結(jié)構(gòu)與運算,順序棧案例2,,則棧1的棧頂表示為:s->top1,棧2的棧頂表示為:s->top2; 棧1的進棧操作使得棧頂1右(后)移,即s->top1++,
10、棧2進 棧操作使得棧頂2左(前)移,即s->top1--; 棧滿時兩個棧頂相鄰,即s->top1+1==s->top2。,圖3.2 共享堆棧,,,,,,,,棧1,,,棧頂2,,a1,an,b1,bm,棧2,棧底1,,棧底2,0,…,MaxSize-1,,棧頂1,第二節(jié):順序棧,數(shù)據(jù)結(jié)構(gòu)與運算,順序棧案例3進棧,,void Push(ShareStack *s, ElementType e, int i)
11、 /*將元素e壓入棧i(i=1,2)*/{ if (s->top1+1==s->top2) /*棧滿*/ printf(“Full”);else { if (i==1){ s->top1++; s->elem[s->top1]=e ;} else{ s->top2--; s->elem[s->top2]=e ;} }}
12、,第二節(jié):順序棧,數(shù)據(jù)結(jié)構(gòu)與運算,順序棧案例4出棧,,ElementType Pop(ShareStack *s, int i) /*棧i(i=1,2)出棧*/{ if (i==1) if (s->top1==-1) /*棧1空*/ return(nil); else { e=s->elem[s->top1]; s->top1--; return(
13、e); } if (i==2) if (s->top2== MaxSize) /*棧2空*/return(nil);else{ e=s->elem[s->top2]; s->top2++; return(e); }},第二節(jié):順序棧,數(shù)據(jù)結(jié)構(gòu)與運算,,,鏈棧,1、棧的鏈式存儲結(jié)構(gòu)2、鏈棧的基本運算,03,數(shù)據(jù)結(jié)構(gòu)與算法,第三節(jié):鏈棧,鏈棧的存儲結(jié)構(gòu),,#define MAX_SIZ
14、E 100 //設置最大元素個數(shù)typedef int Elemtype;typedef struct snode { ElementType data; struct snode *next;}StackNode;typedef StackNode *LinkStack; / * LinkStack為指向StackNode 的指針類型* /,...,圖3.6 鏈棧,棧頂,,,,,,,,,,,a1,
15、an,an-1,棧底,data,next,Λ,s,,,,數(shù)據(jù)結(jié)構(gòu)與運算,第三節(jié):鏈棧,鏈棧的基本操作,,1.棧初始化棧的初始化實現(xiàn)比較簡單,算法如下:LinkStack StackInit(){ LinkStacks=(LinkStack)malloc(sizeof(StackNode));s->next=0; return (s);}
16、 /* StackInit */2.判斷棧是否為空在判斷棧是否為空時,只需將棧頂指針s->next值與null相比即可,算法實現(xiàn)如下:int StackEmpty(LinkStack s){ return(s->next==NULL);} /* StackEmpt
17、y */,數(shù)據(jù)結(jié)構(gòu)與運算,第三節(jié):鏈棧,鏈棧的基本操作,,3.求棧的長度int StackLength(LinkStack s){LinkStack p=s->next; int length=0;while (p) { length++; p=p->next; }return(length);}
18、 /* StackLength */4.進棧操作//插入元素e為新的棧頂元素void Push(LinkStack s, int e){LinkStack p=(StackNode *)malloc(sizeof(StackNode));p->data=e;p->next=s->next; //如圖②把當前的棧頂元素賦值給新結(jié)點的直接后繼s->next =p;
19、 //如圖③將新的結(jié)點p賦值給棧頂指針} /* Push*/,數(shù)據(jù)結(jié)構(gòu)與運算,第三節(jié):鏈棧,鏈棧的基本操作,,5.出棧操作//若棧不空,則刪除棧頂元素,用e返回值int Pop(LinkStack s){ if (StackEmpty(s))
20、 /*???/return(nil); /* 返回空值*/ else{ LinkStack p=s->next; /*如圖①將棧頂結(jié)點賦值給p*/int e=0; s->next= p->next; /*如圖②使得棧頂指針下移1位,指向后一結(jié)點*/ e=p->data; free(p);
21、 /*釋放結(jié)點p*/ return(e);}} /* Pop*/,數(shù)據(jù)結(jié)構(gòu)與運算,第三節(jié):鏈棧,鏈棧的基本操作,,6.獲取棧頂元素根據(jù)棧頂指針s,可以直接獲取最后入棧的元素。應
22、該注意的是,在進行讀取之前,也要進行??諜z查。相關的算法實現(xiàn)如下:int GetTop(LinkStack s){ if (StackEmpty(s)) return(nil); return(s->next->data);} /* GetTop*/,數(shù)據(jù)結(jié)構(gòu)與運算,,,隊列,1、隊列的定義
23、 3、隊列的存儲結(jié)構(gòu)2、隊列的基本運算,04,數(shù)據(jù)結(jié)構(gòu)與算法,第4節(jié):隊列,隊列的定義,,隊列簡稱為隊,是限定只能在表的一端作插入運算、在另一端作刪除運算的線性表;在表中,允許插入的一端稱作“隊尾”,允許刪除的另一端稱作“隊首”(或“隊頭”);通常將元素插入隊尾的操作稱作為入隊列(或入隊),稱刪除隊首元素的操作為出隊列(或出隊)。,數(shù)據(jù)結(jié)構(gòu)與運算,第4節(jié):隊列,隊列的基本運算,,,數(shù)據(jù)結(jié)構(gòu)與運算,隊列的基本運算如下。(1)
24、InitQueue() 初始化隊列。(2)QueueEmpty(q) 判定隊列q是否為空。(3)QueueLength(q) 求隊列q的長度。 GetHead(q) 獲取隊列q隊首元素的值。(5)AddQueue (q, e) 將元素e入隊。(6)DeleteQueue (q) 刪除隊首元素。,第4節(jié):隊列,隊列的存儲結(jié)構(gòu),,兩種結(jié)構(gòu):(1)順序隊列——采用順序結(jié)構(gòu)存儲(2)鏈式隊
25、列——采用鏈式結(jié)構(gòu)存儲,數(shù)據(jù)結(jié)構(gòu)與運算,,,順序隊列,1、隊列的順序存儲結(jié)構(gòu) 2、順序隊列的基本運算,05,數(shù)據(jù)結(jié)構(gòu)與算法,第5節(jié):順序隊列,隊列的順序存儲結(jié)構(gòu)1,,#define MaxSize n 隊列可能達到的最大長度ntypedef struct { ElementType elem[MaxSize]; int front, rear; /*隊首、隊尾指示器*/} Queue;,數(shù)據(jù)結(jié)構(gòu)與運算,第5
26、節(jié):順序隊列,隊列的順序存儲結(jié)構(gòu)2,,,數(shù)據(jù)結(jié)構(gòu)與運算,,,,,圖3.12 隊列操作,,,,,,,,,,,,,a,b,c,e,rear=4,,,,,,,d,front=-1,,,,,b,c,e,rear=4,,,,,,,d,front=0,,,,,front=rear=4,,,,,,front=rear=-1,,(a) 空隊,(b) a,b,c,d,e入隊,(c) 出隊1次,(d) 出隊4次,隊滿和隊空的條件是什么?,隊空:fron
27、t==rear隊滿:rear==Maxsize-1,?,第5節(jié):順序隊列,隊列的順序存儲結(jié)構(gòu)3,,數(shù)據(jù)結(jié)構(gòu)與運算,當rear=MaxSize-1時,隊列為滿,如果再加入新元素,就會產(chǎn)生"溢出"。但是這種"溢出"并不是真正的溢出,在數(shù)組的前端還可能有空位置,所以這是一種假溢出。,,,,,,,b,c,e,rear=4,,,,,,,d,front=0,,,,,front=rear=4,,,,,,,
28、解決方法:循環(huán)隊列,第5節(jié):順序隊列,隊列的順序存儲結(jié)構(gòu)4,,數(shù)據(jù)結(jié)構(gòu)與運算,為了能夠充分的使用數(shù)組中的存儲空間,把數(shù)組的前端和后端連接起來,形成一個環(huán)形的表,即把存儲隊列元素的表從邏輯上看成一個環(huán),成為循環(huán)隊列(Circular Queue)。,front,,,,,front,rear,front,rear,a,,,front,rear,b,c,d,,,front,rear,a,b,c,d,,,front,rear,a,b,c,,,
29、rear,(a) 空隊列,(b) a入隊列,(c) b,c入隊列,(d) d入隊列(隊滿),(e) 出隊1次,(f) 出隊3次(隊空),隊頭指針進1:front=(front+1)%MaxSize;隊尾指針進1:rear=(rear+1)%MaxSize;,第5節(jié):順序隊列,隊列的順序存儲結(jié)構(gòu)4,數(shù)據(jù)結(jié)構(gòu)與運算,以下是隊空的幾種情況:,初始化時:front=rear=0循環(huán)隊列為空的條件是:front==rear,,,fron
30、t,rear,(a) 空隊列,front,,,rear,(f) 出隊3次(隊空),front=0Rear=0,front=4Rear=4,第5節(jié):順序隊列,隊列的順序存儲結(jié)構(gòu)4,數(shù)據(jù)結(jié)構(gòu)與運算,循環(huán)隊列為滿的條件是:front==(rear+1) % MaxSize,,,front,rear,a,b,c,d,以下是隊滿的幾種情況:,front=0Rear=4,,,front,rear,a,b,c,d,front=3Rear=2
31、,,,front,rear,b,c,d,a,front=1Rear=0,第5節(jié):順序隊列,順序隊列的基本運算1,1)、初始化隊列 InitQueue()CirQueue InitQueue(){CirQueue q;q.front =q.rear =0;return(q);}2)、判定隊列q是否為空QueueEmpty(q)int QueueEmpty(CirQueue q){return(q.front
32、 ==q.rear );},數(shù)據(jù)結(jié)構(gòu)與運算,第5節(jié):順序隊列,順序隊列的基本運算2,3)、 求隊列q的長度QueueLength(q)int QueueLength(CirQueue q){return ((q.rear +MaxSize-q.front )%MaxSize);},數(shù)據(jù)結(jié)構(gòu)與運算,,,front,rear,a,b,c,front=0Rear=3,,,front,rear,a,b,c,d,front=3Re
33、ar=2,第5節(jié):順序隊列,順序隊列的基本運算3,4) 、獲取隊列q隊首元素的值GetHead(q)ElementType GetHead(CirQueue q){if(QueueEmpty(q))return(-1);return(q.elem[(q.front+1)%MaxSize]);},數(shù)據(jù)結(jié)構(gòu)與運算,,,front,rear,,,front,rear,a,b,c,front=0Rear=3,,,fron
34、t,rear,a,b,d,front=4Rear=2,第5節(jié):順序隊列,順序隊列的基本運算4,5) 、AddQueue (q, e) 將元素e入隊void AddQueue(CirQueue *q,ElementType e){if(q->front ==(q->rear +1)%MaxSize)printf("\nfull");else { q->rear =(q
35、->rear +1)%MaxSize; q->elem [q->rear ]=e;}},數(shù)據(jù)結(jié)構(gòu)與運算,6) 、DeleteQueue (q) 刪除隊首元素ElementType DeleteQueue(CirQueue *q){ElementType e;if(q->front ==q->rear )return(-1);else{e=q->elem [
36、(q->front +1)%MaxSize];q->front=(q->front +1)%MaxSize;return(e);}},,,鏈式隊列,1、鏈式隊列的存儲結(jié)構(gòu) 2、鏈式隊列的基本運算,06,數(shù)據(jù)結(jié)構(gòu)與算法,第6節(jié):鏈式隊列,鏈式隊列的存儲結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu)與運算,3.6.1 隊列的鏈式存儲結(jié)構(gòu),隊首指針front,圖3.16 鏈隊列,…,,隊尾指針rear,,,,Λ,,,,,a2,a1
37、,an,ΛΛ,頭結(jié)點,,,隊首指針 front,隊尾指針 rear,(b) 非空鏈隊列,(a) 空鏈隊列,第6節(jié):鏈式隊列,鏈式隊列的存儲結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu)與運算,typedef struct Qnode{ ElementType data; //結(jié)點數(shù)據(jù)域 struct Qnode *next; //結(jié)點指針域}QueueNode; typedef struct{ QueueNod
38、e *front,*rear; //隊首和隊尾指針}LinkQueue;,第6節(jié):鏈式隊列,鏈式隊列的基本操作,數(shù)據(jù)結(jié)構(gòu)與運算,1.隊列初始化。隊列的初始化實現(xiàn)比較簡單,算法如下:LinkQueue InitQueue(){QueueNode *p;LinkQueue q;p=(QueueNode *)malloc(sizeof(QueueNode));p->next=NULL;
39、 q.front =q.rear =p;return (q);},2. 判斷隊列是否為空int QueueEmpty(LinkQueue q){return (q.front ==q.rear);},第6節(jié):鏈式隊列,鏈式隊列的基本操作,數(shù)據(jù)結(jié)構(gòu)與運算,3.獲取隊首元素ElementType GetHead(LinkQueue q){if(QueueEmpty(q))return (nil);re
40、turn (q.front->next ->data );},第6節(jié):鏈式隊列,鏈式隊列的基本操作,數(shù)據(jù)結(jié)構(gòu)與運算,4. 入隊操作//插入元素e為q的新的隊尾元素void AddQueue(LinkQueue *q,ElementType e){QueueNode *p;p=(QueueNode *)malloc(sizeof(QueueNode)); if(!p)
41、 {printf(“存儲分配失敗!\n”);return;}p->data =e;p->next =NULL;q->rear ->next =p; //把擁有元素e新結(jié)點p賦值給原隊尾結(jié)點的后繼q->rear =p; //把當前的p設置為隊尾結(jié)點,rear指向p},第6節(jié):鏈式隊列,鏈式隊列的基本操作,數(shù)據(jù)結(jié)構(gòu)與運算,5.出隊操作//若隊列不空
42、,刪除q的隊頭元素,用e返回其值ElementType DeleteQueue(LinkQueue *q){if(QueueEmpty(*q))return (-1);else{ElementType e;QueueNode *p;p=q->front->next; //將欲刪除的隊頭結(jié)點暫存給pq->front->next =p->n
43、ext ; //將原隊頭結(jié)點后繼賦值給頭結(jié)點后繼e=p->data ; //將欲刪除的隊頭結(jié)點的值賦值給eif(p==q->rear)q->rear =q->front ;free(p);return(e);}},,,本章實訓,07,數(shù)據(jù)結(jié)構(gòu)與算法,,,約瑟夫環(huán)的實現(xiàn)(P58),,鏈式隊列分隊簡單實現(xiàn),順序共享棧的簡單實現(xiàn),,棧
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)與算法——c語言和java語言描述 ppt及答案和其他資源01 緒論
- 數(shù)據(jù)結(jié)構(gòu)c語言回文判斷(運用棧以及隊列完成)
- 數(shù)據(jù)結(jié)構(gòu)與算法分析—c語言描述課后答案2
- 《數(shù)據(jù)結(jié)構(gòu)——c語言描述》習題及答案-耿國華
- 數(shù)據(jù)結(jié)構(gòu)c語言描述習題及答案耿國華
- 《數(shù)據(jù)結(jié)構(gòu)》實驗二棧和隊列
- 數(shù)據(jù)結(jié)構(gòu)用c語言描述課后習題答案
- 數(shù)據(jù)結(jié)構(gòu)、算法與應用c++語言描述習題參考答案doc
- 數(shù)據(jù)結(jié)構(gòu)算法與應用-c++語言描述(清晰版)
- 數(shù)據(jù)結(jié)構(gòu)的c語言算法
- 數(shù)據(jù)結(jié)構(gòu)實驗報告——棧和隊列
- 數(shù)據(jù)結(jié)構(gòu)第3章棧和隊列自測卷答案
- 課程設計-- 數(shù)據(jù)結(jié)構(gòu)—用c語言描述
- 數(shù)據(jù)結(jié)構(gòu) 習題 第三章 棧和隊列 答案
- 數(shù)據(jù)結(jié)構(gòu)實驗2棧和隊列迷宮問題求解
- 數(shù)據(jù)結(jié)構(gòu)實驗2棧和隊列迷宮問題求解
- 譚浩強c語言_數(shù)據(jù)結(jié)構(gòu)
- 數(shù)據(jù)結(jié)構(gòu)習題解析-面向?qū)ο蠓椒ê蚦++語言描述-殷人昆
- 數(shù)據(jù)結(jié)構(gòu)c語言經(jīng)典題庫含答案
- c語言與數(shù)據(jù)結(jié)構(gòu)考試大綱
評論
0/150
提交評論