数据结构附录习题及B卷答案答案(2)

2019-06-11 17:47

A、堆排序 B、直接插入排序 C、快速排序 D、冒泡排序

2. 已知一个有向图的邻接矩阵表示,要删除所有从第i个结点发出的边,应该: A)将邻接矩阵的第i行删除 B)将邻接矩阵的第i行元素全部置为0 C)将邻接矩阵的第i列删除 D)将邻接矩阵的第i列元素全部置为0 3.有一个含头结点的双向循环链表,头指针为head, 则其为空的条件是: A. head->priro==NULL B. head->next==NULL

C. head->next==head D. head->next-> priro==NULL

4. 在顺序表 ( 3, 6, 8, 10, 12, 15, 16, 18, 21, 25, 30 ) 中,用折半法查找关键码值11,所需的关键码比较次数为:

A) 2 B) 3 C) 4 D) 5 5. 以下哪一个不是队列的基本运算?

A)从队尾插入一个新元素 B)从队列中删除第i个元素 C)判断一个队列是否为空 D)读取队头元素的值 6. 在长度为n的顺序表的第i个位置上插入一个元素(1≤ i ≤n+1),元素的移动次数为: A) n – i + 1 B) n – i C) i D) i – 1 7.对于只在表的首、尾两端进行插入操作的线性表,宜采用的存储结构为: A) 顺序表 B) 用头指针表示的循环单链表 C) 用尾指针表示的循环单链表 D) 单链表

8.对包含n个元素的哈希表进行查找,平均查找长度为:

A) O(log2n) B) O(n) C) O(nlog2n) D) 不直接依赖于n

9.将一棵有100个结点的完全二叉树从根这一层开始,每一层从左到右依次对结点

进行编号,根结点编号为1,则编号最大的非叶结点的编号为: A、48 B、49 C、50 D、51

10.某二叉树结点的中序序列为A、B、C、D、E、F、G,后序序列为B、D、C、A、F、G、E,则其左子树中结点数目为:

A)3 B)2 C)4 D)5 四、填空题(10分,每空1分)

1.填空完成下面一趟快速排序算法:

int QKPass ( RecordType r [ ], int low, int high) { x = r [ low ];

while ( low < high ) {

while ( low < high && r [ ]. key >= x.key )

high - -;

if ( low < high )

{ r [ ] = r [ high ]; low++; }

while ( low < high && r [ ]. key < x. key ) low++;

if ( low < high )

{ r [ ] = r [ low ]; high--; } }

r [ low ] = x; return low ;

}

2. 假设用循环单链表实现队列,若队列非空,且队尾指针为R, 则将新结点S加入队列时,需执行下面语句: ; ;R=S;

3.通常是以算法执行所耗费的 和所占用的 来判断一个算法的优劣。 4.已知一个3行、4列的二维数组A(各维下标均从1开始),如果按“以列为主”的顺序

存储,则排在第8个位置的元素是: 5.高度为h的完全二叉树最少有 个结点。

五、构造题(20 分) 1.(4分)已知数据结构DS的定义如下,请给出其逻辑结构图示。

DS = (D, R)

D = { a, b, c, d, e, f, g } R = { T }

T = { , , , , , ,

, , , , , }

2.(6分)对以下关键字序列建立哈希表:(SUN, MON, TUE, WED, THU, FRI, SAT),哈希函数为H(K) =(K中最后一个字母在字母表中的序号)MOD 7。用线性探测法处理冲突,要求构造一个装填因子为0.7的哈希表,并计算出在等概率情况下查找成功的平均查找长度。

3.(6分)将关键字序列(3,26,12,61,38,40,97,75,53, 87)调整为大根堆。 4.(4分)已知权值集合为:{ 5,7,2,3,6,9 },要求给出哈夫曼树,并计算其带权路径长度WPL。

六、算法分析题(10分)

阅读下面程序,并回答有关问题。其中BSTree为用二叉链表表示的二叉排序树类型。 (1) 简要说明程序功能。(5分) (2) n个结点的满二叉树的深度h是多少?(3分) (3) 假设二叉排序树*bst是有n个结点的满二叉树,给出算法的时间复杂度。(2分)

int Proc (BSTree *bst, KeyType K) { BSTree f, q, s;

s=(BSTree)malloc(sizeof(BSTNode));

s-> key = K; s-> lchild = NULL; s-> rchild = NULL; if ( *bst == NULL ) { *bst = s; return 1; } f = NULL; q = *bst; while( q != NULL )

{ if ( K < q -> key )

{ f = q; q = q -> lchild; } else

{ f = q; q = q -> rchild; }

}

if ( K < f -> key ) f -> lchild = s; else f -> rchild = s; return 1; }

七、算法设计题(25分)

1. 已知一个带头结点的整数单链表L,要求将其拆分为一个正整数单链表L1和一个负整数单链表L2。(9分)

2. 无向图采用邻接表存储结构,编写算法输出图中各连通分量的结点序列。(8分)

3. 编写一个建立二叉树的算法,要求采用二叉链表存储结构。(8分)

数据结构 附录A 样卷一参考答案 一:判断题

题号 答案 1 × 2 × 3 √ 4 × 5 √ 6 √ 7 √ 8 √ 9 × 10 × 二:选择题

题 1 2 C 3 A 4 D 5 D 6 D 7 B 8 D 9 D 10 A 11 A 12 C 13 B 14 C 15 C 16 B 17 C 18 19 B C 20 B 答 B 三:填空

1, 表长的一半 2, 排好序列 3, 4, 312 5,N+1 6,s->next=p->next P->next=s 7.路径递增 8.log2N +1 9.后序 10.97 11.链域个数不同 12.63 13,1476 14. P->next=head 15,散列查找 16,先进先出 17,5 18,FDBECA 19.将矩阵第i行全部置0

四,1,

计算函数值

key Key%7 75 5 33 5 52 3 41 6 12 5 88 4 66 3 27 6 (1)哈希表(4分,每对1个0.5分)

index key 0 27 1 2 3 52 4 88 5 75 6 33 7 41 8 12 9 66 (2)比较次数(3分)

key Cmp 75 1 33 2 52 1 41 2 12 4 88 1 66 7 27 5 ASL=(1+2+1+2+4+1+7+5)/8=23/8

5, (1)

3 1 0 2 4 5 6 7 (2) ASL=(1+2*2+4*3+1*4)/8=21/8=2.62

2,参见p164;p172;


数据结构附录习题及B卷答案答案(2).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:2016-2022年中国烟酸行业市场分析及投资可行性研究报告(目录)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: