#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#define MaxSize 5
typedef struct{
int data[MaxSize];
int front,rear;
}SqQueue;
int IniteQueue(SqQueue *Q){
Q->front=0;
Q->rear=MaxSize-1;
printf("该循环队列已完成初始化\n\n");
return 1;
}
int isEmpty(SqQueue Q){
if((Q.rear+1)%MaxSize==Q.front)
return 1;
else
return 0;
}
int length(SqQueue Q){
return((Q.rear-Q.front+MaxSize+1)%MaxSize);
}
int EnQueue(SqQueue *Q,int e){
if((Q->rear+2)%MaxSize==Q->front){
printf("该循环队列已满 本次入队操作非法\n\n");
return 0;
}
Q->rear=(Q->rear+1)%MaxSize;
Q->data[Q->rear]=e;
printf("本次入队元素:%d\n\n",e);
return 1;
}
int DeQueue(SqQueue *Q,int *e){
if(isEmpty(*Q)){
printf("该循环队列为空 本次出队操作非法\n\n");
return 0;
}
*e=Q->data[Q->front];
Q->front=(Q->front+1)%MaxSize;
printf("本次出队元素:%d\n\n",*e);
return 0;
}
int GetHead(SqQueue Q){
if(isEmpty(Q)){
printf("该循环队列为空 本次查对头元素操作非法\n\n");
return 0;
}
printf("循环队列当前对头元素为:%d\n\n",Q.data[Q.front]);
return Q.data[Q.front];
}
int main(){
SqQueue Q;
int discard;
IniteQueue(&Q);
if(isEmpty(Q))
printf("当前该循环队列为空\n\n");
else
printf("当前该循环队列的长度为%d\n\n",length(Q));
EnQueue(&Q,9);
EnQueue(&Q,5);
EnQueue(&Q,2);
EnQueue(&Q,7);
EnQueue(&Q,9);
if(isEmpty(Q))
printf("当前该循环队列为空\n\n");
else
printf("当前该循环队列的长度为%d\n\n",length(Q));
DeQueue(&Q,&discard);
if(isEmpty(Q))
printf("当前该循环队列为空\n\n");
else
printf("当前该循环队列的长度为%d\n\n",length(Q));
GetHead(Q);
return 1;
}