#GESP202409C5T1. 单选题(每题 2 分,共 30 分)

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

第 1 题 下面关于链表和数组的描述,错误的是( )。

{{ select(1) }}

  • 数组大小固定,链表大小可动态调整。
  • 数组支持随机访问,链表只能顺序访问。
  • 存储相同数目的整数,数组比链表所需的内存多。
  • 数组插入和删除元素效率低,链表插入和删除元素效率高。

第 2 题 通过( )操作,能完成在双向循环链表结点 p 之后插入结点 s 的功能(其中 next 域为结点的直接后继,prev 域为结点的直接前驱)。

{{ select(2) }}

  • p->next->prev = s; s->prev = p; p->next = s; s->next = p->next;
  • p->next->prev = s; p->next = s; s->prev = p; s->next = p->next;
  • s->prev = p; s->next = p->next; p->next = s; p->next->prev = s;
  • s->next = p->next; p->next->prev = s; s->prev = p; p->next = s;

第 3 题 对下面两个函数,说法错误的是( )。

{{ select(3) }}

  • sumA体现了迭代的思想。
  • SumB采用的是递归方式。
  • SumB函数比SumA的时间效率更高。
  • 两个函数的实现的功能相同。

第 4 题 有如下函数 fun,则 fun(20, 12) 的返回值为( )。

{{ select(4) }}

  • 20
  • 12
  • 4
  • 2

第 5 题 下述代码实现素数表的埃拉托斯特尼筛法,筛选出所有小于等于 nn 的素数,则横线上应填的最佳代码是( )。

{{ select(5) }}

  • for (int j = i; j <= n; j++)
  • for (int j = i * i; j <= n; j++)
  • for (int j = i * i; j <= n; j += i)
  • for (int j = i; j <= n; j += i)

第 6 题 下述代码实现素数表的线性筛法,筛选出所有小于等于 nn 的素数,则横线上应填的代码是( )。

{{ select(6) }}

A. for (int j = 0; j < primes.size() && i * primes[j] <= n; j++) B. for (int j = 1; j < primes.size() && i * j <= n; j++) C. for (int j = 2; j < primes.size() && i * primes[j] <= n; j++) D. 以上都不对


第 7 题 下面函数可以将 nn 的所有质因数找出来,其时间复杂度是( )。

{{ select(7) }}

  • O(n2)O(n^2)
  • O(n log n)O(n\ log\ n)
  • O(nlog n)O(\sqrt{n}\log\ n)
  • O(n)O(n)

第 8 题 现在用如下代码来计算 xnx^{n}nnxx 相乘),其时间复杂度为( )。

{{ select(8) }}

  • O(n)O(n)
  • O(n2)O(n^2)
  • O(log n)O(log\ n)
  • O(n log n)O(n\ log\ n)

第 9 题 假设快速排序算法的输入是一个长度为 nn 的已排序数组,且该快速排序算法在分治过程总是选择第一个元素作为基准元素。下面选项( )描述的是在这种情况下的快速排序行为。

{{ select(9) }}

  • 快速排序对于此类输入的表现最好,因为数组已经排序。
  • 快速排序对于此类输入的时间复杂度是 O(n log n)O(n\ log\ n)
  • 快速排序对于此类输入的时间复杂度是 O(n2)O(n^2)
  • 快速排序无法对此类数组进行排序,因为数组已经排序。

第 10 题 考虑以下C++代码实现的归并排序算法:

对长度为 n 的数组 arr,挑用函数 merge_sort(a,0,n-1),在排序过程中 merge 函数的递归调用次数大约是( )。

{{ select(10) }}

  • O(1)O(1)
  • O(n)O(n)
  • O(log n)O(log\ n)
  • O(n log n)O(n\ log\ n)

第 11 题 现在有 nn 个人要过河,每只船最多载 22 人,船的承重为 100kg100kg。下列代码中,数组 weight 中保存有 nn 个人的体重(单位为kgkg),已经按从小到大排好序,代码输出过河所需要的船的数目,采用的思想为( )。

{{ select(11) }}

  • 枚举算法
  • 贪心算法
  • 迭代算法
  • 递归算法

第 12 题 关于分治算法,以下哪个说法正确?

{{ select(12) }}

  • 分治算法将问题分成子问题,然后分别解决子问题,最后合并结果。
  • 归并排序不是分治算法的应用。
  • 分治算法通常用于解决小规模问题。
  • 分治算法的时间复杂度总是优于 O(n log(n))O(n\ log(n))

第 13 题 根据下述二分查找法,在排好序的数组 1,3,6,9,17,31,39,52,61,79中查找数值 31,循环 while (left <= right) 执行的次数为( )。

{{ select(13) }}

  • 1
  • 2
  • 3
  • 4

第 14 题 以下关于高精度运算的说法错误的是( )。

{{ select(14) }}

  • 高精度计算主要是用来处理大整数或需要保留多位小数的运算。
  • 大整数除以小整数的处理的步骤可以是,将被除数和除数对齐,从左到右逐位尝试将除数乘以某个数,通过减法得到新的被除数,并累加商。
  • 高精度乘法的运算时间只与参与运算的两个整数中长度较长者的位数有关。
  • 高精度加法运算的关键在于逐位相加并处理进位。

第 15 题n=7n=7 时,下面函数的返回值为( )。

{{ select(15) }}

  • 105
  • 840
  • 210
  • 420