通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"考研真题" 试卷中 2019年考研408计算机统考真题在线评测(附答案) 中有题目如下:
第1题
请设计一个队列,要求满足:①初始时队列为空;②入队时,允许增加队列 占用空间;③出队后,出队元素所占用的空间可重复使用,即整个队列所占用的空间只增不减; ④入队操作和出队操作的时间复杂度始终保持为 O(1)。请回答下列问题:
(1)该队列是应选择链式存储结构,还是应选择顺序存储结构?
(2)画出队列的初始状态,并给出判断队空和队满的条件。
(3)画出第一个元素入队后的队列状态。
(4)给出入队操作和出队操作的基本过程。
【答案解析】
(1)顺序存储无法满足要求②的队列占用空间随着入队操作而增加。根据要求来分析:要求 ①容易满足;链式存储方便开辟新空间,要求②容易满足;对于要求③,出队后的结点并不 真正释放,用队头指针指向新的队头结点,新元素入队时,有空余结点则无须开辟新空间, 赋值到队尾后的第一个空结点即可,然后用队尾指针指向新的队尾结点,这就需要设计成一 个首尾相接的循环单链表,类似于循环队列的思想。设置队头、队尾指针后,链式队列的入 队操作和出队操作的时间复杂度均为 O(1),要求④可以满足。因此,采用链式存储结构(两 段式单向循环链表),队头指针为 front,队尾指针为 rear。
(2)该循环链式队列的实现,可以参考循环队列,不同之处在于循环链式队列可以方便增加 空间,出队的结点可以循环利用,入队时空间不够也可以动态增加。同样,循环链式队列也 要区分队满和队空的情况,这里参考循环队列牺牲一个单元来判断。初始时,创建只有一个 空闲结点的循环单链表,头指针 front 和尾指针 rear 均指向空闲结点,如下图所示。
队空的判定条件: front == rear。 队满的判定条件: front == rear->next 。
(3)插入第一个元素后的状态如下图所示。
(4)操作的基本过程如下:
入队操作:
则在 rear 后面插入一个新的空闲结点;
入队元素保存到 rear 所指结点中;rear=rear->next;返回。
若(front==rear) //队空
则出队失败,返回;
取 front 所指结点中的元素 e;front=front->next;返回 e。
所属试卷:2019年考研408计算机统考真题在线评测(附答案)
设字符集 S 包含 7 个字符,各字符出现的频次分别为
关系数据库管理系统能实现的专门关系运算包括( )。
在下列关系运算中,不改变关系表中的属性个数但能减少元组
在长度为n的有序线性表中进行二分查找,最坏情况下需要比
算法的空间复杂度是指( )。
在数据库中,数据模型包括数据结构、数据操作和( )。
有以下程序程序的运行结果是( )。
有以下程序:程序运行后的输出结果是( )。
编写程序,其功能为打印如下图所示图形。 * *** *
在Python中,不论类的名字是什么,构造方法的名字都
#编写一个函数,从键盘上输入两个数,求最大公约数和最小
已知x={1:1,2:2},那么执行语句x[2]=4之
编程计算分段函数:输入x的值,输出函数y的值。参考答案
关闭linux系统(不重新启动)使用的命令答:halt
在/root文件夹下查找后缀为.cpp的文件。答:fi
下面哪个文件用来设置 X window 的显示分辨率?
存储引擎事务是不安全的,且不支持外键,但它占用空
视图是从 _____ 或其它视图导出的虚表。
创建表时,表示定义唯一约束的是( )
下面有关主键和外键之间的关系描述,正确的是。
假定主存地址为32位,按字节编址,指令Cache和数据
(枚举因数)从小到大打印正整数 n 的所有正因数,试补
C语言中,数组名是一个不可变的_____量,不能对它进
预处理命令行都必须以_____号开始。
输入 :10 7 1 4 3 2 5 9 8 0 6输
如果开始时计算机处于小写输入状态,现在有一只小老鼠反复
输出:( )
计算机界的最高奖是( )。
(排列数)输入两个正整数 n,m(1≤n≤20,1≤m
更多选择题
更多填空题
全国计算机等级考试《二级Java语言程序设计》真题(五)
全国计算机等级考试《二级Java语言程序设计》真题(四)
全国计算机等级考试《二级Java语言程序设计》真题(三)
全国计算机等级考试《二级Java语言程序设计》真题(二)
全国计算机等级考试《二级Java语言程序设计》真题(一)
计算机二级Python语言程序设计模拟试卷
Python第三方库