1651: 队列-基本操作(顺序存储,不建议学生做)
金币值:2
定数:8
时间限制:1.000 s
内存限制:128 M
正确:3
提交:3
正确率:100.00% 命题人:
题目描述
#请补充完整下列函数,注意不要修改其它代码。 #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个元素,以空格分隔
第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:否)