您好,登錄后才能下訂單哦!
今天小編給大家分享一下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
");
}
以上就是“C語言中循環隊列如何實現”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。