通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"考研真题" 试卷中 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计算机统考真题在线评测(附答案)
已知类IMS中两个成员函数的声明,另有两个对象定义为I
给定程序MODI1.C中函数fun的功能是:从s所指字
请补充fun函数,该函数的功能是:按‘0’到‘9’统计
以下选项中叙述正确的是( )。
己知x=[3,7,5],那么执行语句x=x.sort
下面结构体的定义语句中,错误的是( )。
请读以下函数假设机器的无符号整数字长为16位,若调用此
局域网的硬件组成包括网络服务器、( )、网络适配器、网
下列叙述中对的的是
设计一个shell程序,添加一个新组为class1,然
/是Linux所有路径的开始,简称Linux的根目录
连接是一种特殊的等值连接,它结果中不含重复的属
create use创建用户时,用户帐号的格式为
某人想要在电子邮件中传送一个文件,他可以借助
(10分)在进行外部排序时,可使用置换-选择排序生成初
设有以下共用体类型说明和变量定义,则变量d在内存所占字
已知a=13,b=6,a%b的十进制数值为_____。
有如下程序:程序运营后的输出成果是( )
(矩形计数)平面上有n个关键点,求有多少个四条边都和x
给定程序中函数fun的功能是:首先将大写字母转换为对应
有以下结构体说明、变量定义和赋值语句struct ST
在关系A(S,SN,D)和B(D,CN,NM)中,A的
(取石子)Alice 和 Bob 两个人在玩取石子游戏
输入:QuanGuoLianSai输出:( )
输入:100110101100110110101111
(读入整数)请完善下面的程序,使得程序能够读入两个 i
输入:1 2 3 4 5 6 0 7输出:( )
下列关于最短路算法的说法正确的有( )。
是目前互联网上常用的E-mail服务协议。
输入:20 12输出:_____
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2