中国大学MOOC-陈越、何钦铭-数据结构-2016秋期末考试
来源:互联网 发布:单片机液晶数字钟论文 编辑:程序博客网 时间:2024/05/23 01:22
判断题
1-1
答案:F
1-2
对一棵平衡二叉树,所有非叶结点的平衡因子都是0,当且仅当该树是完全二叉树。(2分)
答案:F
1-3
无向连通图所有顶点的度之和为偶数。 (2分)
答案:T
1-4
对N个不同的数据采用冒泡排序进行从大到小的排序,当元素基本有序时交换元素次数肯定最多。 (2分)
答案:F
1-5
若用平方探测法解决冲突,则插入新元素时,若散列表容量为质数,插入就一定可以成功。 (2分)
答案:F
选择题
2-1
设栈S和队列Q的初始状态均为空,元素a、b、c、d、e、f、g依次进入栈S。若每个元素出栈后立即进入队列Q,且7个元素出队的顺序是b、d、c、f、e、a、g,则栈S的容量至少是: (2分)
A、1
B、2
C、3
D、4
答案:C
2-2
在下列所示的平衡二叉树中,插入关键字48后得到一棵新平衡二叉树。在新平衡二叉树中,关键字37所在结点的左、右子结点中保存的关键字分别是: (4分)
A、13、48
B、24、48
C、24、53
D、24、90
答案:C
2-3
线性表、堆栈、队列的主要区别是什么?(2分)
A、线性表用指针,堆栈和队列用数组
B、堆栈和队列都是插入、删除受到约束的线性表
C、线性表和队列都可以用循环链表实现,但堆栈不能
D、堆栈和队列都不是线性结构,而线性表是
答案:B
2-4
对
A、树中一定没有度为1的结点
B、树中两个权值最小的结点一定是兄弟结点
C、树中任一非叶结点的权值一定不小于下一层任一结点的权值
D、该树一定是一棵完全二叉树
答案:D
2-5
在并查集问题中,已知集合元素0~8所以对应的父结点编号值分别是{ 1, -4, 1, 1, -3, 4, 4, 8, -2 }(注:−n-n−n表示树根且对应集合大小为nnn),那么将元素6和8所在的集合合并(要求必须将小集合并到大集合)后,该集合对应的树根和父结点编号值分别是多少? (4分)
A、1和-6
B、4和-5
C、8和-5
D、8和-6
答案:B
2-6
要判断一个整数
A、
B、
C、
D、
答案:C
2-7
在一个有权无向图中,如果顶点b到顶点a的最短路径长度是10,顶点c与顶点b之间存在一条长度为3的边。那么下列说法中有几句是正确的? (2分)
1.c与a的最短路径长度就是13
2.c与a的最短路径长度就是7
3.c与a的最短路径长度不超过13
4.c与a的最短路径不小于7
A、1句
B、2句
C、3句
D、4句
答案:D
2-8
将MMM个元素存入用长度为SSS的数组表示的散列表,则该表的装填因子为: (2分)
A、
B、
C、
D、
答案:D
2-9
给定输入序列 {4371, 1323, 6173, 4199, 4344, 9679, 1989} 以及散列函数
A、1, 3, 3, 9, 4, 9, 9
B、1, 3, 4, 9, 7, 5, -1
C、1, 3, 4, 9, 5, 0, 8
D、1, 3, 4, 9, 5, 0, 2
答案:A
2-10
在拓扑排序算法中用堆栈和用队列产生的结果会不同吗?(2分)
A、是的肯定不同
B、肯定是相同的
C、有可能会不同
D、以上全不对
答案:C
2-11
将 {28, 15, 42, 18, 22, 5, 40} 逐个按顺序插入到初始为空的最小堆(小根堆)中。则该树的前序遍历结果为:(4分)
A、5, 18, 15, 28, 22, 42, 40
B、5, 15, 18, 22, 28, 42, 40
C、5, 18, 28, 22, 15, 42, 40
D、5, 15, 28, 18, 22, 42, 40
答案:C
2-12
将1~6这6个键值插到一棵初始为空的二叉搜索树中。如果插入完成后,搜索树结构如图所示,问:可能的插入序列是什么? (2分)
A、1 2 3 4 5 6
B、4 1 2 3 5 6
C、4 1 3 2 6 5
D、4 1 3 2 5 6
答案:D
2-13
给定一有向图的邻接表如下。从顶点V1出发按广度优先搜索法进行遍历,则得到的一种顶点序列为: (2分)
A、V1,V2,V3,V4,V5
B、V1,V2,V3,V5,V4
C、V1,V3,V2,V4,V5
D、V1,V4,V3,V5,V2
答案:C
2-14
已知一个图的邻接矩阵如下,则从顶点V1出发按深度优先搜索法进行遍历,可能得到的一种顶点序列为: (2分)
A、V1,V2,V3,V4,V5,V6
B、V1,V2,V4,V5,V6,V3
C、V1,V3,V5,V2,V4,V6
D、V1,V3,V5,V6,V4,V2
答案:B
2-15
给出关键字序列{ 4321, 56, 57, 46, 28, 7, 331, 33, 234, 63 },下面哪个选择是按次位优先(LSD)链式基数排序进行了一趟分配和收集的结果? (2分)
A、→331→4321→33→63→234→56→46→57→7→28
B、→4321→331→33→63→234→56→46→57→7→28
C、→56→28→4321→331→33→234→46→57→63→7
D、→57→46→28→7→33→234→63→56→4321→331
答案:B
2-16
将序列{ 2, 12, 16, 88, 5, 10, 34 }排序。若前2趟排序的结果如下:
第1趟排序后:2, 12, 16, 10, 5, 34, 88
第2趟排序后:2, 5, 10, 12, 16, 34, 88
则可能的排序算法是:(2分)
A、冒泡排序
B、快速排序
C、归并排序
D、插入排序
答案:B
2-17
给定有权无向图的邻接矩阵如下,其最小生成树的总权重是:(2分)
A、24
B、23
C、18
D、17
答案:B
2-18
在利用堆栈将下列哪个中缀表达式转换为后缀表达式过程中,堆栈的操作系列为:
A、2*(3+4)*5+6
B、2*(3+4*5)+6
C、2*(3+4*5+6)
D、以上都是
答案:A
2-19
采用线性探测冲突解决策略,
A、按a1、a2、a3、a4顺序和按a1、a3、a4、a2顺序,平均成功查找长度一样;
B、按a1、a3、a2、a4顺序和按a3、a1、a2、a4顺序,平均成功查找长度一样;
C、按a1、a3、a2、a4顺序和按a4、a1、a2、a3顺序,平均成功查找长度一样;
D、按任何插入顺序,其平均成功查找长度都一样.
答案:D
2-20
将10, 12, 1, 14, 6, 5, 8, 15, 3, 9, 7逐个按顺序插入到初始为空的最小堆中,然后连续执行两次删除最小元素操作(DeleteMin),再插入4,16,此后堆顶的元素是什么? (2分)
A、4
B、5
C、7
D、9
答案:A
程序填空题
3-1
下列代码的功能是将小顶堆H中指定位置P上的元素的整数键值下调D个单位,然后继续将H调整为小顶堆。
void DecreaseKey( int P, int D, PriorityQueue H ){ int i, key; key = H->Elements[P] - D; for ( i = P; H->Elements[i/2] > key; i/=2 ) H->Elements[i]=H->Elements[i/2]; H->Elements[i] = key;}
3-2
下列代码的功能是将一列元素{ r[1] … r[n] }按非递减顺序排序。普通选择排序是每次仅将一个待排序列的最小元放到正确的位置上,而这个另类的选择排序是每次从待排序列中同时找到最小元和最大元,把它们放到最终的正确位置上。
void sort( list r[], int n ) { int i, j, mini, maxi; for (i=1; i<n-i+1; i++) { mini = maxi = i; for( j=i+1; j<=n-i+1; ++j ){ if( r[j]->key < r[mini]->key ) mini = j; else if(r[j]->key > r[maxi]->key) maxi = j; } if( mini!=i ) swap(&r[mini], &r[i]); if( maxi != n-i+1 ){ if( maxi==i ) swap(&r[mini], &r[n-i+1]); else swap(&r[maxi], &r[n-i+1]); } }}
3-3
本题要求给出希尔排序对给定初始序列{9, 8, 7, 6, 5, 4, 3, 2, 1}利用增量序列{1, 3, 7}进行排序的分步结果。将每步结果填在下列空中。注意:相邻数字间必须有一个空格,开头结尾不得有多余空格。
原始序列 9 8 7 6 5 4 3 2 1
增量7排序后 2 1 7 6 5 4 3 9 8 (2分)
增量3排序后 2 1 4 3 5 7 6 9 8 (2分)
增量1排序后 1 2 3 4 5 6 7 8 9
3-4
本题要求给出下图中从A到其他顶点的最短路径。注意:填空时不能有任何空格。
终点 路径
A->B AB
A->C AC
A->D ABGED(2分)
A->E ABGE(2分)
A->F ABGEF(2分)
A->G ABG
编程题
本题要求根据给定的一棵二叉树的后序遍历和中序遍历结果,输出该树的先序遍历结果。
输入格式:
第一行给出正整数NNN(≤30\le 30≤30),是树中结点的个数。随后两行,每行给出NNN个整数,分别对应后序遍历和中序遍历结果,数字间以空格分隔。题目保证输入正确对应一棵二叉树。
输出格式:
在一行中输出Preorder:以及该树的先序遍历结果。数字间有1个空格,行末不得有多余空格。
输入样例:
7
2 3 1 5 7 6 4
1 2 3 4 5 6 7
输出样例:
Preorder: 4 1 3 2 6 5 7
参考代码
#include <iostream> #include <cstring> using namespace std; void getpre(int *post, int *in, int n) { if(n <= 0) return; int root = post[n - 1]; int i; for(i = 0; i < n; i++) { if(in[i] == root) { break; } } cout << ' ' << root; getpre(post, in, i); getpre(post + i, in + i + 1, n - i - 1); } int main() { int post[40], in[40]; int n; cin >> n; int i, j; for(i = 0; i < n; i++) { scanf("%d", &post[i]); } for(i = 0; i < n; i++) { scanf("%d", &in[i]); } printf("Preorder:"); getpre(post, in, n); printf("\n"); return 0; }
- 中国大学MOOC-陈越、何钦铭-数据结构-2016秋期末考试
- 中国大学MOOC-陈越、何钦铭-数据结构-2017春期末考试
- 中国大学MOOC-陈越、何钦铭-数据结构-2016秋2题
- 中国大学MOOC-陈越、何钦铭-数据结构-2016秋期中考试
- 中国大学MOOC-陈越、何钦铭-数据结构-2016秋期中考试
- 中国大学MOOC-陈越、何钦铭-数据结构 List Leaves
- 中国大学MOOC-陈越、何钦铭-数据结构 File Transfer
- 中国大学MOOC-陈越、何钦铭-数据结构 统计工龄
- 中国大学MOOC-陈越、何钦铭-数据结构-2017春
- 中国大学MOOC-陈越、何钦铭-数据结构-2017秋 02-线性结构4 Pop Sequence
- 【中国大学MOOC-陈越、何钦铭-数据结构-2017秋】最大子列和问题
- 最大子列和问题(20) - 中国大学MOOC-陈越、何钦铭-数据结构基础习题集
- 中国大学MOOC-陈越、何钦铭-数据结构基础习题——总结
- 中国大学MOOC-陈越、何钦铭-数据结构基础习题集 00-自测1. 打印沙漏(20)
- 中国大学MOOC-陈越、何钦铭-数据结构 Maximum Subsequence Sum
- 中国大学MOOC-陈越、何钦铭-数据结构 一元多项式的乘法与加法运算
- 中国大学MOOC-陈越、何钦铭-数据结构 树的同构
- 中国大学MOOC-陈越、何钦铭-数据结构 是否同一棵二叉搜索树
- 《Linux内核的设计与实现》读书笔记(二)---从内核出发
- java的基本数据类型
- 图片拉伸的处理的三种方式
- Mac RobotFramework 环境安装
- DevExpress.XtraGrid常用设置
- 中国大学MOOC-陈越、何钦铭-数据结构-2016秋期末考试
- Java内存分配---堆与栈
- 扫 雷 小 游 戏
- 编译原理_PL/0_词法分析
- 从C到C++要注意的33件事(2)
- 网易面试题之小易是一个数论爱好者,并且对于一个数的奇数约数十分感兴趣。一天小易遇到这样一个问题: 定义函数f(x)为x最大的奇数约数,x为正整数。 例如:f(44) = 11. 现在给出一个N,需要求
- Xshell使用技巧总结
- Java EE服务端学习(1)
- docs - marahon-lb virtual host小实验