数据结构复习题与答案 下载本文

内容发布更新时间 : 2025/1/11 18:14:44星期一 下面是文章的全部内容请认真阅读。

.

一.是非题

1. 数据结构(应该是抽象数据类型)可用三元式表示(D,S,P)。其中:D是数据对象,S是D上的关系,P是对D的基本操作集。(f)

2 简单地说,数据结构是带有结构的数据元素的集合。(t)

3 判断带头结点的非空循环单链表(头指针为L)中指针p所指结点是最后一个元素结点 的条件是:p->next==L。(t)

4 线性表的链式存储结构具有可直接存取表中任一元素的优点。(f) 5 线性表的顺序存储结构优于链式存储结构。(f)

6. 在单链表P指针所指结点之后插入S结点的操作是: P->next= S ; S-> next = P->next;。(f)

(顺序弄反了S-> next = P->next; P->next= S ;)

7 对于插入、删除而言,线性表的链式存储优于顺序存储。(t)

8. 顺序存储方式的优点是存储密度大,且插入、删除运算效率高。(f) 9. 栈和队列是操作上受限制的线性表。(t)

10. 队列是与线性表完全不同的一种数据结构。(f) (栈和队列是操作上受限制的线性表)

11. 队列是一种操作受限的线性表,凡对数据元素的操作仅限一端进行。(f) (两端)

12. 栈和队列也是线性表。如果需要,可对它们中的任一元素进行操作。(f)

( “如果需要,可对它们中的任一元素进行操作.” 这里的意思是在O(1)的时间来读和改某个元素。比如数组的直接索引。

栈:如果需要,每一次只能对栈顶的元素进行操作

队列:如果需要,每一次只能对两端,或者只能对队列头的元素进行操作。) 13. 栈是限定仅在表头进行插入和表尾进行删除运算的线性表。(f)

14. 二叉树中每个结点有两个子结点,而对一般的树,则无此限制,所以,二叉树是树的 特殊情形。(f)

(二叉树和树相互独立)

15 二叉树是一棵结点的度最大为二的树。(f) (二叉树和树相互独立)

16 赫夫曼树中结点个数一定是奇数。(t)

17 在二叉树的中序遍历序列中,任意一个结点均处在其左孩子结点的后面。(t) (LDR)

18 假设B是一棵树,B′是对应的二叉树。则B的后根遍历相当于B′的后序遍历 。(f) (后根遍历相当于中序遍历)

i-1

19. 通常,二叉树的第i层上有2个结点。(f)

i-1

(应该为1~2个)

20. 中序线索二叉树的优点是便于在中序下查找直接前驱结点和直接后继结点。(t) 21 二叉树的先序遍历序列中,任意一个结点均处在其孩子结点的前面。(t) 22 由树结点的先根序列和后根序列可以唯一地确定一棵树。(t) 23 邻接多重表可以用以表示无向图,也可用以表示有向图。(f) (只能表示无向图,有向图用十字链表)

24 可从任意有向图中得到关于所有顶点的拓扑次序。(f) (带环图没有)

25 有向图的十字链表是将邻接表和逆邻接表合二为一的链表表示形式。(t)

.

.

26 关键路径是AOE网中源点到汇点的最短路径。(f) (最长)

27 连通图G的生成树是一个包含G的所有n个顶点和n-1条边的子图。(f) (极大连通子图)

28 一个无向图的连通分量是其极大的连通子图。(t) 29 十字链表可以表示无向图,也可用以表示有向图。(f) (有向图)

30 邻接表可以表示有向图,也可以表示无向图。(t) 31. 二叉排序树的平均查找长度为O(logn)。(t) 32. 二叉排序树的最大查找长度与(LOG2N)同阶。(f)

33 选用好的HASH函数可避免冲突。(f) (无法避免,只能减少冲突)

34 折半查找不适用于有序链表的查找。(t) (因链表地址不连续)

35. 对于目前所知的排序方法,快速排序具有最好的平均性能。(t) 36 对于任何待排序序列来说,快速排序均快于冒泡排序。(f) (快速排序希望初始数据随机)

37 在最坏情况下,堆排序的时间性能是O(nlogn),比快速排序好(t) (堆排序与初始数据无关)

38 快速排序具有最好的平均时间性能,它在任何时候的时间复杂度都是O(n log n)。(f)

2

(退化到n)

39. 字符串是数据对象特定的线性表。(t) 40. 空串与空格串是相同的。(f) (空串长度为0,空格串长度为其长度)

41. 对于一棵m阶的B-树.树中每个结点至多有m 个关键字.除根之外的所有非终端结点至 少有┌m/2┐个关键字。(f)

(至少有m颗子树,关键字数目至少m-1)

42. 当二叉排序树是一棵平衡二叉树时,其平均查找长度为O(log2n)。(t) 43. 广义表的表头和表尾都是广义表。(f)

(表头可能是原子,也可能是列表,而其表尾必定为列表) 44 二维数组是其数据元素为线性表的线性表。(t)

选择题。

1 从逻辑上可以把数据结构分成( c )。

A. 动态结构和静态结构 B. 顺序组织和链接组织 C. 线性结构和非线性结构 D. 基本类型和组合类型 2 线性表L在( b )情况下适于使用链表结构实现。

A. 不需修改L的结构 B. 需不断对L进行删除、插入 C. 需经常修改L中结点值 D. L中含有大量结点 3 带头结点的单链表L为空的判断条件是 b 。 带头结点的循环链表L为空的判断条件是 c 。

A. L==null B. L->next==null C. L->next==L D. L!=null

.

.

4 若顺序表中各结点的查找概率不等,则可用如下策略提高顺序查找的效率:若找到指定 的结点,将该结点与其后继(若存在)结点交换位置,使得经常被查找的结点逐渐移至 表尾。以下为据此策略编写的算法,请选择适当的内容,完成此功能。 顺序表的存储结构为: typedef struct{

ElemType *elem; //数据元素存储空间,0号单元作监视哨 int length; //表长度 }SSTable;

int search_seq(SSTable ST,KeyType key)

{ //在顺序表ST中顺序查找关键字等于key的数据元素。

//若找到,则将该元素与其后继交换位置,并返回其在表中的位置,否则为0。 ST.elem[0].key=key; i=ST.length;

while(ST.elem[i].key!=key) f ; if( G )

{ST.elem[i]←→ST.elem[i+1]; e ; }

return i; }

A. i>0 B. i>=0 C. i

E. i++ F. i-- G. A和C同时满足 H. B和D同时满足

5 若入栈顺序为A、B、C、D、E,则下列( d )出栈序列是不可能的。 A.A、B、C、D、E B.B、C、D、A、E C.C、D、B、E、A D.D、E、C、A、B 6 递归程序可借助于( c )转化为非递归程序。 a.线性表 b.队列 c: 栈 d.数组 7 在下列数据结构中( c )具有先进先出(FIFO)特性, ( b )具有先进后出(FILO)特性。

a.线性表 b.栈 c.队列 d.广义表

8 若对编号为1,2,3的列车车厢依次通过扳道栈进行调度,不能得到 ( e ) 的序列。 a:1,2,3 b:1,3,2 c:2,1,3 d:2,3,1 e:3,1,2 f:3,2,1 9 在计算递归函数时,如不用递归过程,应借助于( b ) 这种数据结构。 A. 线性表 B. 栈 C. 队列 D. 双向队列 10 若带头结点的链表只设尾结点指针。下列选择中( c )最适用于队列。 A)单链表 B)双向链表 C循环单链表 D)双向循环链表 11 栈和队列的一个共同点是( c )。

A. 都是先进先出 B. 都是先进后出 C. 只允许在端点处插入和删除元素 D. 没有共同点

12 循环队列用数组A[0..m-1]存放其元素值,设头尾指针分别为front和rear,则当前队列中

的元素个数是( c )。

A. rear-front-1 B. Rear-front+1

.