求一个C语言 循环队列的插入 完整程序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了求一个C语言 循环队列的插入 完整程序相关的知识,希望对你有一定的参考价值。

参考技术A (1)编写一个程序,实现顺序环形队列的各种基本运算,并在此基础上设计一个主程序完成如下功能:
(1)初始化队列q;
(2)判断队列q是否非空;
(3)依次进队元素100、909、44、8;
(4)出队一个元素,输出该元素;
(5)输出队列q的元素个数;
(6)依次进队元素-67、55、99、70;
(7)输出队列q的元素个数;
#include<stdio.h>
#include<malloc.h>
#define QUEUE_INIT_SIZE 100
#define QUEUEINCREMENT 10
#define OK 1
#define TURE 1
#define FALSE 0
#define ERROR 0
#define INFEASIBLE -1
#define OVERFLOW -2
typedef int Status;
typedef int QElemType;
typedef struct

QElemType *base;
int front;
int rear;
SqQueue;

Status InitQueue(SqQueue &Q)

Q.base=(QElemType *)malloc
(QUEUE_INIT_SIZE*sizeof(QElemType));
if(!Q.base)
exit(OVERFLOW);
Q.front=Q.rear=0;
return OK;

int QueueNumElem(SqQueue Q)

return (Q.rear-Q.front)%QUEUE_INIT_SIZE;

Status EnQueue(SqQueue &Q,QElemType e)

if((Q.rear+1)%QUEUE_INIT_SIZE==Q.front)
return ERROR;
Q.base[Q.rear]=e;
Q.rear=(Q.rear+1)%QUEUE_INIT_SIZE;

return OK;

SqQueue DeQueue(SqQueue Q,int e)

int i;
if(Q.front==Q.rear)
printf("队为空!\n");
for(i=e;i<Q.rear;i++)
Q.base[i]=Q.base[i+1];
Q.rear--;
return Q;

int main()

SqQueue Q,Q1;
static int qele=0;
int i,j=0,k=0,m=0;
static int frontd=Q.front;
i=InitQueue(Q);
if(i==1)
printf("队初始化成功!!\n");
else
printf("队初始化失败!!\n");
if(Q.front!=Q.rear)
printf("队不为空!!\n");
else
printf("队为空L!!\n");
printf("输入数据(END of '9999'):");
scanf("%d",&qele);
while(qele!=9999||Q.rear==Q.front)

EnQueue(Q,qele);
scanf("%d",&qele);

frontd=Q.front;
while(Q.rear!=Q.front)

printf(" %d ",Q.base[Q.front]);
Q.front++;
j++;

printf("\n");
Q.front=frontd;
printf("输入要出队的元素:");
scanf("%d",&j);
while(Q.front!=Q.rear)

if(Q.base[Q.front]==j)

printf("%d\n",Q.base[Q.front]);
Q=DeQueue(Q,Q.front);
m++;
break;

Q.front++;

Q.front=frontd;
while(Q.front!=Q.rear)

printf(" %d ",Q.base[Q.front]);
Q.front++;

printf("\n");
Q.front=frontd;
printf("队的长度:%d\n",Q.rear-Q.front);
printf("输入数据(END of '9999'):");
scanf("%d",&qele);
while(qele!=9999||Q.rear==Q.front)

EnQueue(Q,qele);
scanf("%d",&qele);

Q.front=frontd;
printf("队的长度:%d\n",Q.rear-Q.front);
Q.front=frontd;
printf("出队顺序:");
while(Q.rear!=Q.front)

printf(" %d ",Q.base[Q.front]);
Q=DeQueue(Q,Q.front);
m++;

printf("end\n");
Q.front=0;
Q.rear=m;
while(Q.rear!=Q.front)

free(Q.base);
//Q.base++;
Q.front++;
if(Q.rear-1==Q.front)
printf("队已经释放!\n");

return 0;
本回答被提问者和网友采纳

以上是关于求一个C语言 循环队列的插入 完整程序的主要内容,如果未能解决你的问题,请参考以下文章

数据结构C语言版 —— 队列+循环队列实现

数据结构C语言版 —— 队列+循环队列实现

数据结构学习笔记——顺序存储结构实现循环队列

C语言数据结构与算法------队列全面总结

栈和队列C语言实现附加力扣题

[数据结构] 队列 (C语言)