小編這次要給大家分享的是C語言如何實現循環隊列,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
注意事項:
1、循環隊列,是隊列的順序表示和實現。因為是尾進頭出,所以和順序棧不同的是需要將順序隊列臆造成一個環狀的空間,以便在尾部添加滿之后從頭部空位開始插入。
2、也可以使用數組隊列,也就是不能動態增長的順序隊列,這樣不需要每次取模大值來構成環形空間。每次插入新的隊列尾元素時,尾指針增1,每當刪除隊列頭元素時,頭指針增1。
3、尾指針會出現在頭指針之前,由此特性,循環隊列在無法預估使用大小時,不宜使用。
4、在每一個指針遞增的表達式中,都要加上一個% MAXQUEUE已使得每一次增值都在范圍內。
#include<stdio.h> #include<stdlib.h> #define MAXQUEUE 100 typedef struct { int *base; int front; int rear; }SqQueue, *Sqqueue; Sqqueue Creat(Sqqueue q); void Enqueue(Sqqueue q, int e); void Dequeue(Sqqueue q, int *e); void Traverse(Sqqueue q); int main() { SqQueue q; int e; Sqqueue p = Creat(&q); Traverse(p); Dequeue(p, &e); Traverse(p); printf("the number that was deleted is :%d", e); return 0; } Sqqueue Creat(Sqqueue q) { Sqqueue p = q; p->base = (int *)malloc(MAXQUEUE * sizeof(int));//這里注意和鏈不同,開辟的是整片的數據空間,以base為基址 p->front = p->rear = 0; for (int i = 1; i < 10; i++) Enqueue(p, i); return p; } void Enqueue(Sqqueue q, int e) { if ((q->rear + 1) % MAXQUEUE == q->front) //如果尾指針下一個是頭指針,即將其看成滿隊列(少利用一個空間)。否則只看頭指針等于尾指針會有歧義。 exit(1); q->base[q->rear] = e; q->rear = (q->rear + 1) % MAXQUEUE; } void Dequeue(Sqqueue q, int *e) { if (q->front == q->rear) exit(1); (*e) = q->base[q->front]; q->front = (q->front + 1) % MAXQUEUE; } void Traverse(Sqqueue q) { for (int i = q->front; q->rear != i; i = (i + 1) % MAXQUEUE) printf("%d->", q->base[i]); printf("NULL\n"); }
文章題目:C語言如何實現循環隊列-創新互聯
分享網址:http://m.newbst.com/article4/cejoie.html
成都網站建設公司_創新互聯,為您提供品牌網站設計、標簽優化、品牌網站建設、微信小程序、網站營銷、Google
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯