C語言實(shí)現(xiàn)循環(huán)隊(duì)列
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)循環(huán)隊(duì)列的具體代碼,供大家參考,具體內(nèi)容如下
注意事項(xiàng):
1、循環(huán)隊(duì)列,是隊(duì)列的順序表示和實(shí)現(xiàn)。因?yàn)槭俏策M(jìn)頭出,所以和順序棧不同的是需要將順序隊(duì)列臆造成一個環(huán)狀的空間,以便在尾部添加滿之后從頭部空位開始插入。
2、也可以使用數(shù)組隊(duì)列,也就是不能動態(tài)增長的順序隊(duì)列,這樣不需要每次取模最大值來構(gòu)成環(huán)形空間。每次插入新的隊(duì)列尾元素時,尾指針增1,每當(dāng)刪除隊(duì)列頭元素時,頭指針增1。
3、尾指針會出現(xiàn)在頭指針之前,由此特性,循環(huán)隊(duì)列在無法預(yù)估使用大小時,不宜使用。
4、在每一個指針遞增的表達(dá)式中,都要加上一個% MAXQUEUE已使得每一次增值都在范圍內(nèi)。
#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));//這里注意和鏈不同,開辟的是整片的數(shù)據(jù)空間,以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) //如果尾指針下一個是頭指針,即將其看成滿隊(duì)列(少利用一個空間)。否則只看頭指針等于尾指針會有歧義。 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"); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言初識動態(tài)內(nèi)存管理malloc calloc realloc free函數(shù)
動態(tài)內(nèi)存是相對靜態(tài)內(nèi)存而言的。所謂動態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存2022-03-03C語言動態(tài)內(nèi)存分配和內(nèi)存操作函數(shù)使用詳解
但是在實(shí)際的編程中,往往會發(fā)生這種情況,即所需的內(nèi)存空間取決于實(shí)際輸入的數(shù)據(jù),而無法預(yù)先確定 。為了解決上述問題,C語言提供了一些內(nèi)存管理函數(shù),這些內(nèi)存管理函數(shù)可以按需要動態(tài)的分配內(nèi)存空間,也可把不再使用的空間回收再次利用2022-12-12