SHAOXIAOJ正在加载中...

1651: 队列-基本操作(顺序存储,不建议学生做)

金币值:2 定数:8 时间限制:1.000 s 内存限制:128 M
正确:3 提交:3 正确率:100.00% 命题人:
点赞量:0 收藏量:0 题目类型:程序 知识点: 数据结构-栈与队列

题目描述

#请补充完整下列函数,注意不要修改其它代码。
#include <stdio.h>
#include <stdlib.h>

#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define MAXSIZE 20 /* 存储空间初始分配量 */
typedef int Status;
typedef int QElemType; /* QElemType类型根据实际情况而定,这里假设为int */
/* 循环队列的顺序存储结构 */
typedef struct {
	QElemType data[MAXSIZE];
	int front;    /* 头指针 */
	int rear; /* 尾指针,若队列不空,指向队列尾元素的下一个位置 */
} SqQueue;
Status visit(QElemType c) {
	printf("%d ",c);
	return OK;
}
/* 初始化一个空队列Q */
Status InitQueue(SqQueue &Q) {
	Q.front=0;
	Q.rear=0;
	return  OK;
}
/* 将Q清为空队列 */
Status ClearQueue(SqQueue &Q) {
	__________;
	return OK;
}
/* 若队列Q为空队列,则返回TRUE,否则返回FALSE */
Status QueueEmpty(SqQueue Q) {
	if(__________) /* 队列空的标志 */
		return TRUE;
	return FALSE;
}
/* 返回Q的元素个数,也就是队列的当前长度 */
int QueueLength(SqQueue Q) {
	return ___________;
}
/* 若队列不空,则用e返回Q的队头元素,并返回OK,否则返回ERROR */
Status GetHead(SqQueue Q,QElemType &e) {
	if(QueueEmpty(Q)) /* 队列空 */
		return ERROR;
	____________;
	return OK;
}
/* 若队列未满,则插入元素e为Q新的队尾元素 */
Status EnQueue(SqQueue &Q,QElemType e) {
	if (___________) /* 队列满的判断 */
		return ERROR;
	_________; /* 将元素e赋值给队尾 */
	_________;/* rear指针向后移一位置, */
	/* 若到最后则转到数组头部 */
	return  OK;
}
/* 若队列不空,则删除Q中队头元素,用e返回其值 */
Status DeQueue(SqQueue &Q,QElemType &e) {
	if (______) /* 队列空的判断 */
		return ERROR;
	________; /* 将队头元素赋值给e */
	________; /* front指针向后移一位置, */
	/* 若到最后则转到数组头部 */
	return  OK;
}
/* 从队头到队尾依次对队列Q中每个元素输出 */
Status QueueTraverse(SqQueue Q) {
	int i;
	i=Q.front;
	while(______) {
		________;
		i=(i+1)%MAXSIZE;
	}
	printf("\n");
	return OK;
}
int main(void) {
	Status j;
	int i=0,l;
	QElemType d;
	SqQueue Q;
	InitQueue(Q);
	printf("初始化队列后,队列空否?%d(1:空 0:否)\n",QueueEmpty(Q));
	do {
		scanf("%d",&d);
		if(d==-1) break;
		i++;
		EnQueue(Q,d);
	} while(i<MAXSIZE-1);
	printf("队列长度为: %d\n",QueueLength(Q));
	printf("现在队列空否?%d(1:空 0:否)\n",QueueEmpty(Q));
	scanf("%d",&i);
	printf("连续%d次由队头删除元素,队尾插入元素:\n",i);
	for(l=1; l<=i; l++) {
		DeQueue(Q,d);
		printf("删除的元素是%d\n",d);
		scanf("%d",&d);
		printf("插入的元素:%d\n",d);
		EnQueue(Q,d);
	}
	l=QueueLength(Q);
	printf("现在队列中的元素为:\n");
	QueueTraverse(Q);
	while(QueueLength(Q)>2) {
		DeQueue(Q,d);
		printf("删除的元素值为%d\n",d);
	}
	j=GetHead(Q,d);
	if(j)
		printf("现在队头元素为: %d\n",d);
	ClearQueue(Q);
	printf("清空队列后, 队列空否?%d(1:空 0:否)\n",QueueEmpty(Q));
	return 0;
}

输入格式

共3行:
第1行:待入队列的元素,以空格分隔,以-1结束,总数不超过19个
第2行:待入队列元素个数i
第3行:共i个元素,以空格分隔

输出格式

见样例

输入样例    复制

3 2 1 -1
5
5 6 7 8 9

输出样例    复制

初始化队列后,队列空否?1(1:空 0:否)
队列长度为: 3
现在队列空否?0(1:空 0:否)
连续5次由队头删除元素,队尾插入元素:
删除的元素是3
插入的元素:5
删除的元素是2
插入的元素:6
删除的元素是1
插入的元素:7
删除的元素是5
插入的元素:8
删除的元素是6
插入的元素:9
现在队列中的元素为:
7 8 9
删除的元素值为7
现在队头元素为: 8
清空队列后, 队列空否?1(1:空 0:否)