编写一个程序实现顺序循环队列的各种基本运算,并在此基础上设计一个主程序完成如下功能
(1)初始化队列Q。(2)判断队列Q是否非空。(3)依次进队元素A,B,C。(4)出队一个元素,输出该元素。(5)输出队列Q的元素个数。(6)依次进队元素D,E,F。(7...
(1)初始化队列Q。(2)判断队列Q是否非空。(3)依次进队元素A,B,C。(4)出队一个元素,输出该元素。(5)输出队列Q的元素个数。(6)依次进队元素D,E,F。(7)输出队列Q的元素个数。(8)输出出队序列。(9)释放队列。
展开
1个回答
2013-05-10
展开全部
#include <stdio.h>
#include <malloc.h>
#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);
}
#include <malloc.h>
#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);
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询