C语言——循环队列的实现
循环队列
循环队列可以理解为一个环,实际上是将一个普通队列的尾部连上头部构成的,所以在实现循环队列时,需要两个指针front和rear分别指示队列头元素及队列尾元素的位置。
在初始化建空队列时可以令front=rear=0,这样当插入新元素时,尾指针rear加1表示向后移动一位,同理,当删除队列头元素时,头指针front加1表示队列头部一个元素出队列,下一个元素成队首。这样,front始终指向队头元素,rear始终指向队尾元素的下一位。
假设一个空队列空间为10,如果存入10个数据,那么此时队列就会满,但此时会发现front=rear,因为rear指向队尾元素的下一位,此时队尾元素的下一位恰好为队首元素。此时会出现一个问题,刚开始是说当front==rear时,队列为空队列,队列满时也满足front=rear。
此时可以采用一个方法:少用一个元素空间,约定以“队列首指针在队列尾指针的下一位置上”作为队列呈“满”状态的标志。
代码实现如下
#include "stdio.h"
#include "stdlib.h"
#define MAXQSIZE 100 //最大队列长度
typedef int QElemType;
typedef struct{
QElemType *base;
int front; //头指针
int rear; //尾指针
}SqQueue;
int InitQueue(SqQueue *q){
q->base=(QElemType *)malloc(MAXQSIZE * sizeof(QElemType));
if(!q->base)
exit(0); //分配失败
q->front=0;
q->rear=0;
return 1;
}
//返回队列q的元素个数
int QueueLength(SqQueue q){
return (q.rear-q.front+MAXQSIZE)%MAXQSIZE;
}
//向q队尾插入元素
int EnQueue(SqQueue *q,QElemType e){
if((q->rear+1)%MAXQSIZE==q->front) //队列满
return 0;
q->base[q->rear]=e;
q->rear=(q->rear+1)%MAXQSIZE;
return 1;
}
//删除q的队首元素,用e返回其值
int DeQueue(SqQueue *q,QElemType *e){
if(q->front==q->rear) //队列为空
return 0;
*e=q->base[q->front];
q->front=(q->front+1)%MAXQSIZE;
return 1;
}
int main(){
SqQueue q;
int e=0;
InitQueue(&q);
EnQueue(&q,2);
printf("长度:%d\n",QueueLength(q));
EnQueue(&q,5);
printf("长度:%d\n",QueueLength(q));
DeQueue(&q,&e);
printf("长度:%d\n",QueueLength(q));
printf("e= %d\n",e);
DeQueue(&q,&e);
printf("长度:%d\n",QueueLength(q));
printf("e= %d\n",e);
return 0;
}