App下載

實例代碼展示C語言中循環(huán)隊列的實現(xiàn)

忽而相遇 2021-08-19 14:00:59 瀏覽數(shù) (1917)
反饋

說起循環(huán),都會想到for、while以及do……while三種循環(huán)結(jié)構(gòu)。在C語言中,隊列的循環(huán)具體是要如何實現(xiàn)的呢?下面,將和大家分享C語言中循環(huán)隊列的文章,幫助大家對于C語言循環(huán)隊列的學(xué)習(xí)。

注意事項:

1、循環(huán)隊列,是隊列的順序表示和實現(xiàn)。因為是尾進頭出,所以和順序棧不同的是需要將順序隊列臆造成一個環(huán)狀的空間,以便在尾部添加滿之后從頭部空位開始插入。
2、也可以使用數(shù)組隊列,也就是不能動態(tài)增長的順序隊列,這樣不需要每次取模最大值來構(gòu)成環(huán)形空間。每次插入新的隊列尾元素時,尾指針增1,每當(dāng)刪除隊列頭元素時,頭指針增1。
3、尾指針會出現(xiàn)在頭指針之前,由此特性,循環(huán)隊列在無法預(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) //如果尾指針下一個是頭指針,即將其看成滿隊列(少利用一個空間)。否則只看頭指針等于尾指針會有歧義。
 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
");
}

本篇有關(guān)C語言代碼實現(xiàn)循環(huán)隊列的文章就介紹到此結(jié)束了,想要了解更多關(guān)于C語言循環(huán)和隊列的內(nèi)容,推薦大家前往C語言教程進行系統(tǒng)地學(xué)習(xí)。


C

0 人點贊