#include
#include
#define Maxqsize 5
typedef char ElemType;
typedef struct
{
ElemType elem[Maxqsize];
int front,rear;
}SqQueue;
void InitQueue(SqQueue *&q)
{
q=(SqQueue *)malloc (sizeof(SqQueue));
q->front=q->rear=0;
}
void ClearQueue(SqQueue *&q)
{
free(q);
}
int QueueLength(SqQueue *q)
{
return (q->rear-q->front+Maxqsize)%Maxqsize;
}
int QueueEmpty(SqQueue *q)
{
return(q->front==q->rear);
}
int enQueue(SqQueue *&q,ElemType e)
{
if ((q->rear+1)%Maxqsize==q->front)
return 0;
q->rear=(q->rear+1)%Maxqsize;
q->elem[q->rear]=e;
return 1;
}
int deQueue(SqQueue *&q,ElemType &e)
{
if (q->front==q->rear)
return 0;
q->front=(q->front+1)%Maxqsize;
e=q->elem[q->front];
return 1;
}
void main()
{
ElemType e;
SqQueue *q;
printf("(1)初始化队列Q\n");
InitQueue(q);
printf("(2)依次进队列元素A,B,C\n");
if (enQueue(q,'A')==0) printf("队满,不能进队\n");
if (enQueue(q,'B')==0) printf("队满,不能进队\n");
if (enQueue(q,'C')==0) printf("队满,不能进队\n");
printf("(3)队列为%s\n",(QueueEmpty(q)?"空":"非空"));
if (deQueue(q,e)==0)
printf("队空,不能出队\n");
else
printf("(4)出队一个元素%c\n",e);
printf("(5)队列Q的元素个数:%d\n",QueueLength(q));
printf("(6)依次进队列元素D,E,F\n");
if (enQueue(q,'D')==0) printf("队满,不能进队\n");
if (enQueue(q,'E')==0) printf("队满,不能进队\n");
if (enQueue(q,'F')==0) printf("队满,不能进队\n");
printf("(7)队列Q的元素个数:%d\n",QueueLength(q));
printf("(8)出队列序列:");
while (!QueueEmpty(q))
{ deQueue(q,e);
printf("%c ",e);
}
printf("\n");
printf("(9)释放队列\n");
ClearQueue(q);
}