0一.是非题
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)
7 对于插入、删除而言,线性表的链式存储优于顺序存储。(t)
8. 顺序存储方式的优点是存储密度大,且插入、删除运算效率高。(f) 9. 栈和队列是操作上受限制的线性表。(t)
10. 队列是与线性表完全不同的一种数据结构。栈和队列是操作上受限制的线性表(f) 11. 队列是一种操作受限的线性表,凡对数据元素的操作仅限一端进行。对列不是(f) 12. 栈和队列也是线性表。如果需要,可对它们中的任一元素进行操作。(f) 13. 栈是限定仅在表头进行插入和表尾进行删除运算的线性表。(f)
14. 二叉树中每个结点有两个子结点,而对一般的树,则无此限制,所 以,二叉树是树的 特殊情形。(f)
15 二叉树是一棵结点的度最大为二的树二叉树和树相互独立。(f) 16 赫夫曼树中结点个数一定是奇数。(t)
17 在二叉树的中序遍历序列中,任意一个结点均处在其左孩子结点的后面。(t)
18 假设B是一棵树,B′是对应的二叉树。则B的后根遍历相当于B′的后序遍历 后根遍历相当于中序遍历。(f)
19. 通常,二叉树的第i层上有2i-1个结点。应该为1~2i-1个(f)
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) 39. 字符串是数据对象特定的线性表。(t) 40. 空串与空格串是相同的。(f)
41. 对于一棵m阶的B-树.树中每个结点至多有m 个关键字.除根之外的所有非终端结点至 少有┌m/2┐个关键字。(f)
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 C. (rear-front+m)%m D. Rear-front 13 如下关于串的陈述中,正确的是( a, c )。 A. 串是数据元素类型特殊的线性表 B. 串中的元素是字母 C. 串中若干个元素构成的子序列称为子串 D. 空串即为空格串 14 对字符串s=’data-structure’ 执行操作replace(s,substring(s,6,8),’bas’) 的结果是 ( b ) 。 a: ‘database’ b: ‘data-base’ c: ‘bas’ d: ‘data-basucture’ 1 5 设有二维数组A 5 x 7 ,每一元素用相邻的4个字节存储,存储器按字节编址. 已知A的起始地址为100。则按行存储时,元素A06的第一个字节的地址是(d ) 按列存储时,元素A06的第一个字节的地址是( a ) a: 220 b: 200 c: 140 d: 124 16对广义表 A=((a,(b)),(c,()),d)执行操作gettail(gethead(gettail(A))) 的结果是:( b ) 。 a:() b: (()) c: d d: (d) 17 假设用于通讯的电文仅由6个字符组成,字母在电文中出现的频率分别为7, 19, 22, 6, 32, 14。 若为这6个字母设计哈夫曼编码(设生成新的二叉树的规则是按给出的次序从左至 右的结合,新生成的二叉树总是插入在最右),则频率为7的字符编码是( g ),频率 为32的字符编码是( c )。 a: 00 b: 01 c: 10 d: 11 e: 011 f: 110 g: 1110 h:1111 18 对二叉排序树( c )可得到有序序列。 a:按层遍历 b:前序遍历 c:中序遍历 d:后序遍历 19 设一棵二叉树BT的存储结构如下: 1 2 3 4 5 6 7 8 lchild 2 3 0 0 6 0 0 0 data A B C D E F G H rchild 0 5 4 0 8 7 0 0 其中lchild,rchild分别为结点的左、右孩子指针域,data为结点的数据域。则 该二叉树的高度为( d ); 第3层有( a )个结点(根结点为第1层)。 A.2 B. 3 C. 4 D. 5 20 先序遍历图示二叉树可得到( a )的序列。 (A) / \ (B) (C) / \ \ (H) (D) (G) / \ (E) (F) \ (I) a) A B H D E F I C G b) H B E D F I A C G c) H E I F D B G C A 21 在有n个结点的二叉树的二叉链表表示中,空指针数为 n+1;非空指针树为 n-1; ( b )。 a.不定 b.n+1 c.n d.n-1 22 若某二叉树有20个叶子结点,有20个结点仅有一个孩子,则该二叉树的总结点数是 ( c )。度为2的节点n2 = n0 – 1;其中no表示度为0的节点 A.40 B. 55 C. 59 D. 61 23 已知某二叉树的先序遍历次序为abcdefg中序遍历次序为badcgfe, 则该二叉树的后序遍历次序为( c )。层次遍历次序为( a )。 a: abcdefg b: cdebgfa c: bdgfeca d: edcgfba .24 图示的三棵二叉树中( c)为最优二叉树。 A) B) C) c a 2 7 a b c d d b 7 5 2 4 4 5 a b c d 7 5 2 4 25 已知某二叉树的后序遍历和中序遍历次序分别为DBFGECA和BDACFEG。 则其先序遍历次序为( b ),层次遍历次序为( a )。 a: abcdefg b: abdcefg c: abcdfeg d: abcdegf 26 已知某树的先根遍历次序为abcdefg后根遍历次序为cdebgfa。 若将该树转换为二叉树,其后序遍历次序为( d )。 a: abcdefg b: cdebgfa c: cdegbfa d: edcgfba 27 设x和y是二叉树中的任意两个结点,若在先根序列中x在y之前,而在后根序列中x 在y之后,则x和y的关系是( c )。 A. x是y的左兄弟 B. x是y的右兄弟 C. x是y的祖先 D. x是y的子孙 28 用三叉链表作二叉树的存储结构,当二叉树中有n个结点时,有( d )个空指针。 A. n-1 B. n C. n+1 D. n+2 29 对一棵完全二叉树进行层序编号。则编号为n的结点若存在右孩子,其位序是( d )。 编号为n的结点若存在双亲,其位置是( a )。 a: n/2 b: 2n c:2n-1 d:2n+1 e:n f: 2(n+1) 30 设森林F中有三棵树,第一、第二和第三棵树的结点个数分别为m1、m2和m3,则与 森林F对应的二叉树根结点的右子树上的结点个数是( d )。 A. m1 B. m1+m2 C. m3 D. m2+m3 31 下列二叉树中,( a )可用于实现符号不等长高效编码。 a:最优二叉树 b:次优查找树 c:二叉平衡树 d:二叉排序树 32 邻接表存储结构下图的深度优先遍历算法类似于二叉树的( a )遍历。 A. 先根 B. 中根 C. 后根 D. 层次 33 设无向图G = (V,E)和G’= (V’,E’),若G’是G的生成树,则下面不正确的说法是( b )。 A. G’是G的子图 B. G’是G的连通分量(极大连通子图称为连通分量) C. G’是G的无环子图 D. G’是G的极小连通子图且V’= V 34 任何一个连通图的最小生成树( b )。最小生成树其实是最小权重生成树的简称 A.只有一棵 B. 有一棵或多棵 C. 一定有多棵 D. 可能不存在 e f e f 35 深度优先遍历图使用了数据结构(b ),而广度优先遍历图使用了数据结构( c )。 A)数组 B)栈 C)队列 D)线性表 36 已知某有向图的邻接表存储结构如图所示。 0 E 2 1 ∧ 1 D 0 3 4 ∧ 2 C 4 3 B 1 2 0 ∧ 4 A 2 ∧ 根据存储结构依教材中的算法其深度优先遍历次序为( d )。 广度优先遍历此序为( c )。各强连通分量的顶点集为( h )。有向图的极大强连通子图,称为强连通分量 a: abcde. b: edcba. c: ecdab. d: ecadb. e: abc及ed f: bc及aed g: ab及ced h: ac及bed 搜索“diyifanwen.net”或“第一范文网”即可找到本站免费阅读全部范文。收藏本站方便下次阅读,第一范文网,提供最新资格考试认证必看!!!!!数据结构期末复习题及部分答案解析 全文阅读和word下载服务。
相关推荐: