第3章 栈和队列自测卷答案姓名 班级
题号
—?
二
三
四
五
六
总分
题分
15
10
20
20
20
15
100
得分
一、填空题(每空1分,共15分)
【李春葆】向量、栈和队列都是—线性 结构,可以在向量的 任何 一位置插入和 删除元素;对于栈只能在 栈顶 插入和删除元素:对于队列只能在 队尾 插入和 队首删除元素。
栈是一种特殊的线性表,允许插入和删除运算的一端称为栈顶。不允许插入和删
除运算的一端称为栈底 -
队列是被限立为只能在表的一端进行插入运算,在表的另一端进行删除运算的线 性表。
在一个循环队列中,队首指针指向队首元素的前一个 位置。
在具有n个单元的循环队列中,队满时共有 ml个元素。
向栈中压入元素的操作是先移动栈顶指针,后存入元素一
从循环队列中删除一个元素时,苴操作是先 移动队首指针,后 取出元素■
KOo年统考题》带表头结点的空循环双向链表的长度等于 0。
head ∣ L=head | 头结点 ∣ R=head
二、判断正误(判断下列概念的正确性,并作出简要的说明。)(每小题1分,共10分) (×) 1.线性表的每个结点只能是一个简单类型,而链表的每个结点可以是一个复杂
类型。
错,线性表是逻输结构概念,可以顺序存储或链式存储.与元素数据类型无关。
(X ) 2.在表结构中最常用的是线性表,栈和队列不太常用。
错,不一定吧?调用子程序或函数常用,CPU中也用队列。
(√)3.栈是一种对所有插入、删除操作限于在表的一端进行的线性表,是一种后进
先岀型结构。
(√)4.对于不同的使用者,一个表结构既可以是栈,也可以是队列,也可以是线性
表。
正确,都是线性逻辑结构,栈和队列其实是特殊的线性表,对运算的定义略有不同而已。
(×)5.栈和链表是两种不同的数据结构。
错,栈是逻辑结构的概念,是特殊殊线性表,而链表是存储结构概念,二者不是同类项。
(×)6.栈和队列是一种非线性数据结构。
错.他们都是线性逻辑结构,栈和队列其实是特殊的线性表,对运算的定义略有不同而已。
(√)7.栈和队列的存储方式既可是顺序方式,也可是链接方式。
(√)8.两个栈共享一片连续内存空间时,为提高内存利用率,减少溢出机会,应耙
两个栈的栈底分别设在这片内存空间的两端。
(×)9.队是一种插入与删除操作分别在表的两端进行的线性表,是一种先进后岀型结
构。
错,后半句不对。
(×)10. 一个栈的输入序列是12345,则栈的输岀序列不可能是12345。 错.有可能。
单项选择题(每小题1分,共20分)
(B)I. KoO年元月统考题》栈中元素的进出原则是
A.先进先出 B.后进先出C.栈空则进D.栈满则出
(C ) 2. K李春葆》若已知一个栈的入栈序列是1, 2, 3,…,n,其输岀序列为pl, p2, p3,…,Pln 若 pl=n,则 Pi 为
A. i B. n=i C. n-i+1D.不确定
解释:当pl=n,即n是最先岀栈的,根据栈的原理,n必泄是最后入栈的,那么输入顺序
必定是1,2, 3,…,n,则出栈的序列是m…,3, 2, Ia
(B ) 3. E李春葆』判立一个栈ST (最多元素为mθ)为空的条件是
A ? ST-XopoOB . ST->top=0C . ST->top<>mO
D. ST->top=mO
(B ) 4. K李春葆』判泄一个队列QU (最多元素为mθ)为满队列的条件是
A. QU->rear — QU->front = = mθ B? QU->rear — QU->front —1== mθ
C . QU->front = = QU->rearD . QU->front = = QU->rear+l
(D ) 5.数组Q[n]用来表示一个循环队列,f为当前队列头元素的前一位置,
r为队尾元素的位置,假定队列中元素的个数小于n,计算队列中元素的公 式为
(A ) r—f;(B) (n+f—r) % n; ( C ) n÷r-f;( D ) (n+r
-f) % n
6.【98初程P71】 从供选择的答案中,选出应填入下而叙述_丄_内的最确切的解答, 把相应编号写在答卷的对应栏内。
设有4个数据元素ak a2. a3和a4,对他们分别进行栈操作或队操作。在进栈或进队操作时,按al、a2、a3、a4次序每次进入一个元素。假设栈或队的初始状态都是空。
现要进行的栈操作是进栈两次,岀栈一次,再进栈两次,出栈一次:这时,第一次出栈得到 的元素是一 A ,第二次岀栈得到的元素是一 B 是:类似地,考虑对这四个数据 元素进行的队操作是进队两次,岀队一次,再进队两次,出队一次:这时,第一次岀队得到 的元素是一 C ,第二次出队得到的元素是一 D 。经操作后