判断题

1-1
N2logN N^2logN和 NlogN2 NlogN^2​​具有相同的增长速度。 (2分)
答案: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
对 N(N≥2) N(N≥2)个权值均不相同的字符构造哈夫曼树。下列关于该哈夫曼树的叙述中,错误的是: (2分)
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
要判断一个整数 N(>10) N(>10)是否素数,我们需要检查3到 N−−√ \sqrt{N}之间是否存在奇数可以整除 N N。则这个算法的时间复杂度是:(2分)
A、O(N/2)O(N/2)
B、 O(N−−√logN) O(\sqrt{N}logN)
C、 O(N−−√) O(\sqrt{N})
D、 O(0.5logN) O(0.5logN)
答案: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句
答案:B

2-8
将MMM个元素存入用长度为SSS的数组表示的散列表,则该表的装填因子为: (2分)
A、 S+M S+M
B、 M−S M−S
C、 M×S M×S
D、 M/S M/S
答案:D

2-9
给定输入序列 {4371, 1323, 6173, 4199, 4344, 9679, 1989} 以及散列函数 h(X)=X h(X)=X % 10 10。如果用大小为10的散列表,并且用分离链接法解决冲突,则输入各项经散列后在表中的下标为:(-1表示相应的插入无法成功)(2分)
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
在利用堆栈将下列哪个中缀表达式转换为后缀表达式过程中,堆栈的操作系列为: push(′∗′)、push(′(′)、push(′+′)、pop()、pop()、pop()、push(′∗′)、pop()、push(′+′)、pop() push('*') 、push('(')、 push('+')、pop()、pop()、pop()、push('*')、pop()、push('+')、pop() (2分)
A、2*(3+4)*5+6
B、2*(3+4*5)+6
C、2*(3+4*5+6)
D、以上都是
答案:A

2-19
采用线性探测冲突解决策略, hi(k)=(H(k)+i)mod11 hi(k)=(H(k)+i)mod 11,将散列函数值分别等于2、2、3、3的四个对象a1、a2、a3、a4都插入一个大小为11的空散列表(哈希表)中。在不同的插入顺序中,哪句有关插入后散列表平均成功查找长度的判断是错的? (4分)
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秋期末考试相关推荐

  1. 中国大学MOOC-陈越、何钦铭-数据结构-2019秋期末考试

    [PTA]中国大学MOOC-陈越.何钦铭-数据结构-2019秋期末考试 一.判断题: 1-1 对N个不同的数据采用冒泡排序进行从大到小的排序,当元素基本有序时交换元素次数肯定最多. [F] 1-2 2 ...

  2. 中国大学MOOC-陈越、何钦铭-数据结构-2022秋期末考试

                  child != N - 1&&A[child+1]>A[child] Tmp < A[child] A[i] = Tmp PercDown(A ...

  3. 中国大学MOOC-陈越、何钦铭-数据结构-2019夏期末考试(含答案)

    中国大学MOOC-陈越.何钦铭-数据结构-2019夏期末考试(含答案) 判断题 1-1   对N个不同的数据采用冒泡排序进行从大到小的排序,当元素基本有序时交换元素次数肯定最多. (2分) 1-2   ...

  4. 中国大学MOOC-陈越、何钦铭-数据结构-2020春期末考试【个人完整题解记录-判断选择部分】

    欢快地安排了大半个晚上来做这次线上期末考,最后发现每种题型做完后都没摁保存(我就一直纳闷题目列表的状态怎么不会有变化!)...最后几分钟赶紧回忆答案尽可能多的填上去qwq,本来有机会拿50块PAT代金 ...

  5. 中国大学MOOC-陈越、何钦铭-数据结构-2019春期末考试(题目+部分解答)

    欢迎评论(指正或是询问都可),谢谢大家 一.判断题 思路很正常的题目. 1-4反例:4个顶点只用3条边就可以做到全连通.所以边数可能等于顶点个数减一.错误. 二.选择题 2-8需要细心的做一下双旋操作 ...

  6. 中国大学MOOC-陈越、何钦铭-数据结构-2022春期末考试

    按Ctrl+F 查询题目答案

  7. 中国大学MOOC-陈越、何钦铭-数据结构-2020夏期末考试

    5-2 下列代码的功能是对一个给定的图G执行拓扑排序,其中TopNum[]从1开始记录拓扑序. void Topsort( Graph G ) {Queue Q;Vertex V, W;NodePtr ...

  8. 中国大学MOOC-陈越、何钦铭-数据结构-2022春期末考试(2)

    按Ctrl+F 查询题目答案

  9. 中国大学MOOC-陈越、何钦铭-数据结构-2019夏期末考试

    1-1对一棵平衡二叉树,所有非叶结点的平衡因子都是0,当且仅当该树是完全二叉树.(2分)   F 1-2n!是O(n​^n​​)的. (2分)  T 1-3若用平方探测法解决冲突,则插入新元素时,若散 ...

最新文章

  1. javascript 利用 - 枚举思想 - 添加地名的一个小例子
  2. Excel对重复数据分组,求出不同的数据(office 2013)
  3. opengl加载显示3D模型md5mesh类型文件
  4. Java -- 注解 annotation
  5. SpringBoot-@Conditional
  6. 基于微软Synchronization Services双向同步技术在企业项目中的架构应用研究
  7. 在c语言程序中将数据分为两种,2012年计算机二级C语言考点归纳汇总(一至四章)...
  8. Your CPU supports instructions that this TensorFlow binary was not compiled to use AVX AVX2
  9. iOS--数据存储NSUserDefaults
  10. 黑苹果系统坏了如何恢复_黑苹果macOS系统U盘版/恢复版基础安装教程
  11. 恢复计算机硬盘数据,计算机数据恢复,小编教您如何恢复计算机数据
  12. 阶段3 3.SpringMVC·_02.参数绑定及自定义类型转换_4 请求参数绑定集合类型
  13. css对网页模块进行样式定义,模块七 使用CSS样式1217.ppt
  14. fdfs文件服务环境搭建详细教程
  15. 评价类算法之AHP层次分析法
  16. 浙江移动彩信新sp接入指南
  17. 阿里云数据迁移工具解决方案:腾讯云迁移到阿里云
  18. macbook键盘失灵
  19. Python——类和实例
  20. Linux操作系统的主要组成部分

热门文章

  1. 4x root 红米_小米红米Note4X获取root权限教程
  2. 【Java并发编程 】同步——volatile 关键字
  3. 不用linux转录组数据分析,RNA-seq转录组数据分析
  4. 电机驱动电路中的Snubber网络设计
  5. 祖先祖先基因组重建研究
  6. 2023年全国最新会计专业技术资格精选真题及答案18
  7. 计算机文化基础第一章知识点题,计算机文化基础第一章习题与答案
  8. adb root 权限运行
  9. 计算机操作透明化,win10系统如何设置透明化效|win10电脑透明化功能怎么开启
  10. 从视频中截取图像opencv python