#GESP1356. [GESP202603七级] 客观题

[GESP202603七级] 客观题

一、单选题(每题 2 分,共 30 分)

第 1 题 假设一个算法时间复杂度的递推式是 T(n)=2T(n1)+1T(n)=2T(n-1)+1 (nn为正整数),且 T(0)=1T(0)=1,那么这个算法的时间复杂度是 ( )

{{ select(1) }}

  • O(n)O(n)
  • O(nlogn)O(nlogn)
  • O(n2)O(n^2)
  • O(2n)O(2^n)

第 2 题 下面关于“唯一分解定理”和“素数筛法”的说法中,错误的是()。

{{ select(2) }}

  • 如果预处理出 nn 以内每个数的最小质因子,那么可以在 O(logn)O(logn) 时间内完成任意一个不超过 nn 的整数的质因数分解。
  • 线性筛(欧拉筛)能够保证每个合数只被其最小质因子筛掉一次,这一性质依赖于唯一分解定理。
  • 唯一分解定理保证:若一个数未被任何不超过其平方根的质数筛去,则它一定是质数。
  • 唯一分解定理是埃氏筛时间复杂度为O(nloglogn)O(nloglogn) 的根本原因。

第 3 题 若字符串 AA 与字符串 BB 的最长公共子序列 (LCS)(LCS) 长度为55,则 ( )

{{ select(3) }}

  • 它们的编辑距离为 55
  • 它们至少有 55 个公共字符
  • 它们最长公共子串长度为 55
  • 它们一定长度相等

第 4 题 对于一棵包含 nn 个顶点(n2n≥2)的树,其所有顶点的度数之和必定等于 ( )

{{ select(4) }}

  • n1n-1
  • 2n22n-2
  • 2n2n
  • n2n^2

第 5 题 关于哈希表(HashHash TableTable)在不考虑扩容且采用简单均匀哈希函数的前提下,下列说法中错误的是 ( )

{{ select(5) }}

  • 装载因子越大,发生冲突的概率通常越高
  • 开放定址法在删除元素时实现相对复杂
  • 链地址法在最坏情况下查找时间复杂度为 O(n)O(n)
  • 查找哈希表的时间复杂度总是 O(1)O(1)

第 6 题 深度优先搜索 (DFS)(DFS) 在遍历图时,每当访问到某个顶点后,选择一个相邻的未访问顶点继续搜索,直到某个顶点的所有相邻顶点均已被访问,则退回到前一顶点继续搜索。该算法主要运用了 ( )

{{ select(6) }}

  • 分治
  • 贪心
  • 动态规划
  • 回溯

第 7 题 下面程序的运行结果为 ( )

01 #include <iostream>
02 #include <algorithm>
03 
04 bool check(int n, int a[], int k, int dist) {
05     int cnt = 1;
06     int last = a[0];
07
08     for (int i = 1; i < n; i++) {
09         if (a[i] - last >= dist) {
10             cnt++;
11             last = a[i];
12         }
13     }
14
15     return cnt >= k;
16 }
17 
18 int solve(int n, int a[], int k) {
19     std::sort(a, a + n);
20 
21     int l = 0;
22     int r = a[n - 1] - a[0];
23 
24     while (l < r) {
25         int mid = (l + r + 1) / 2;
26
27         if (check(n, a, k, mid))
28             l = mid;
29         else
30             r = mid - 1;
31     }
32 
33     return l;
34 }
35 
36 int main() {
37     int a[] = {1, 2, 8, 4, 9};
38     int n = 5;
39     int k = 3;
40 
41     std::cout << solve(n, a, k) << std::endl;
42
43     return 0;
44 }

{{ select(7) }}

  • 22
  • 33
  • 44
  • 55

第 8 题 下面程序的时间复杂度是( ),假设数组 aa 的值域范围是 DD

01 #include <iostream>
02 #include <algorithm>
03 
04 bool check(int n, int a[], int k, int dist) {
05     int cnt = 1;
06     int last = a[0];
07
08     for (int i = 1; i < n; i++) {
09         if (a[i] - last >= dist) {
10             cnt++;
11             last = a[i];
12         }
13     }
14
15     return cnt >= k;
16 }
17 
18 int solve(int n, int a[], int k) {
19     std::sort(a, a + n);
20 
21     int l = 0;
22     int r = a[n - 1] - a[0];
23 
24     while (l < r) {
25         int mid = (l + r + 1) / 2;
26
27         if (check(n, a, k, mid))
28             l = mid;
29         else
30             r = mid - 1;
31     }
32 
33     return l;
34 }
35 
36 int main() {
37     int a[] = {1, 2, 8, 4, 9};
38     int n = 5;
39     int k = 3;
40 
41     std::cout << solve(n, a, k) << std::endl;
42
43     return 0;
44 }

{{ select(8) }}

  • O(nlogn+nlogD)O(nlogn + nlogD)
  • O(nlognlogD)O(nlognlogD)
  • O(nlogn)O(nlogn)
  • O(nlogD)O(nlogD)

第 9 题 某二叉树共有 1010 个结点,记为 AJA \sim J,已知它的先序遍历序列为: A B D H I E C F J G,中序遍历序列为: H D I B E A F J C G,则该二叉树的后序遍历序列是 ( )

{{ select(9) }}

  • H I D E B J F G C A
  • H I D B E J F G C A
  • I H D E B J F G C A
  • H I D E B F J G C A

第 10 题 下面哪一个可能是下图的深度优先遍历序列 ( )

{{ select(10) }}

  • 1,5,4,8,7,9,6,3,2
  • 1,5,8,4,7,9,6,3,2
  • 2,5,8,7,9,6,3,4,1
  • 8,9,6,3,2,5,1,4,7

第 11 题 下面这个有向图的强连通分量的个数是 ( )

{{ select(11) }}

  • 33
  • 44
  • 55
  • 66

第 12 题 关于泛洪算法(FloodFlood FillFill) 的说法,正确的是 ( )

{{ select(12) }}

  • 泛洪算法只适用于二维网格中的四连通或八连通问题。
  • 泛洪算法必须使用递归方式实现。
  • 泛洪算法本质上是对图进行一次从起点出发的搜索。
  • 泛洪算法只能用于统计连通块个数,不能用于计算面积或周长。

第 13 题66 个字符,它们出现的次数分别为: {2, 3, 3, 4, 6, 8},现在用哈夫曼编码为这些字符编码,最小加权路径长度 WPLWPL (每个字符的出现次数x它的编码长度,再把每个字符结果加起来)的值为 ( )

{{ select(13) }}

  • 5858
  • 6060
  • 6262
  • 6464

第 14 题 关于单链表、双链表和循环链表,下列说法正确的是 ( )

{{ select(14) }}

  • 在单链表中,若已知某结点的指针,则可以在 O(1)O(1) 时间内删除该结点。
  • 循环链表中一定不存在空指针。
  • 在循环双链表中,尾结点的 nextnext 指针一定为 NULLNULL
  • 在带头结点的循环单链表中,判定链表是否为空只需判断头结点的 nextnext 是否指向自身。

第 15 题 下列关于树的遍历的说法中,正确的一项是 ( )

{{ select(15) }}

  • 对任意一棵树进行深度优先遍历,所得序列一定唯一。
  • 已知一棵二叉树的先序遍历和后序遍历序列,可以唯一确定这棵二叉树。
  • 已知一棵二叉树的先序遍历和中序遍历序列,可以唯一确定这棵二叉树。
  • 一棵二叉树的中序遍历序列是单调递增的,则该二叉树一定是二叉平衡树。

二、判断题(每题 2 分,共 20 分)

第 1 题 C++ 语言中,表达式4^2 的结果类型为 int,值为 66

{{ select(16) }}

  • 正确
  • 错误

第 2 题 C++ 中引用可以重新绑定。

{{ select(17) }}

  • 正确
  • 错误

第 3 题C++ 中,若函数形参为引用类型,则在函数内部对该形参的修改会影响对应的实参。

{{ select(18) }}

  • 正确
  • 错误

第 4 题 如果一个最值问题可以用动态规划在多项式时间内求解,那么也一定存在一种贪心策略,可以在多项式时间内求得最优解。

{{ select(19) }}

  • 正确
  • 错误

第 5 题 使用归并排序对 nn 个元素进行排序时,无论最好、最坏还是平均情况,时间复杂度均为 O(nlogn)

{{ select(20) }}

  • 正确
  • 错误

第 6 题 在无向连通图中删除一条边,该图就一定变成非连通图。

{{ select(21) }}

  • 正确
  • 错误

第 7 题 在一个无向图中,每个顶点有不同的编号,在执行深度优先遍历过程中选择下一个顶点时总是优先选择编号更小的相邻顶点,则从指定顶点开始的遍历序列是唯一的。

{{ select(22) }}

  • 正确
  • 错误

第 8 题 若所有字符出现频率相同,则哈夫曼编码一定会得到完全二叉树。

{{ select(23) }}

  • 正确
  • 错误

第 9 题 使用 math.hcmath 头文件中的函数,表达式sin(90) 的结果为 11

{{ select(24) }}

  • 正确
  • 错误

第 10 题 在一个无向连通图中,从任意顶点开始进行深度优先遍历,最终得到的 DFSDFS 生成树一定包含图中的所有顶点。

{{ select(25) }}

  • 正确
  • 错误