2023年09月CCF-GESP编程能力等级认证C++编程五级真题

2024年03月03日

一、单选题(共15题,共30分)

第1题 近年来,线上授课变得普遍,很多有助于改善教学效果的设备也逐渐流行,其中包括比较常用的手写板,那么它属于哪类设备?( )

A:输入
B:输出
C:控制
D:记录

答案:A

第2题 如果 a 和 b 均为 int 类型的变量,且 b 的值不为 0 ,那么下列能正确判断“ a 是 b 的3倍”的表达式是( )。

A:(a >> 3 == b)
B:(a - b) % 3 == 0
C:(a / b == 3)
D:(a == 3 * b)

答案:D

第3题 如果变量 a 和 b 分别为 double 类型和 int 类型,则表达式 (a = 6, b = 3 * (7 + 8) / 2, b += a) 的计算结果为( )。

A:6
B:21
C:28
D:不确定

答案:C

第4题 有关下面C++代码说法错误的是( )。

A:sumA() 用循环方式求从 1 到 N 之和, sumB() 用递归方式求从 1 到 N 之和。
B:默认情况下,如果输入正整数 1000 ,能实现求从 1 到 1000 之和。
C:默认情况下,如果输入正整数 100000 ,能实现求从 1 到 100000 之和。
D:一般说来, sumA() 的效率高于 sumB() 。

答案:C

第5题 下面C++代码以递归方式实现字符串反序,横线处应填上代码是( )。

A:sIn[sIn.length() - 1] + sReverse(sIn.substr(0, sIn.length() - 1));
B:sIn[0] + sReverse(sIn.substr(1, sIn.length() - 1));
C:sReverse(sIn.substr(0, sIn.length() - 1)) + sIn[sIn.length() - 1];
D:sReverse(sIn.substr(1, sIn.length() - 1)) + sIn[sIn.length() - 1];

答案:A

第6题 印度古老的汉诺塔传说:创世时有三根金刚柱,其中一柱从下往上按照大小顺序摞着64片黄金圆盘,当圆盘逐一从一柱借助另外一柱全部移动到另外一柱时,宇宙毁灭。移动规则:在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。下面的C++代码以递归方式实现汉诺塔,横线处应填入代码是( )。

A:Hanoi(B, C, A, N - 2)
B:Hanoi(B, A, C, N - 1)
C:Hanoi(A, B, C, N - 2)
D:Hanoi(C, B, A, N - 1)

答案:B

第7题 根据下面C++代码的注释,两个横线处应分别填入( )。

A:compare 和 isOdd(lstA[i])
B:compare(x1,y1) 和 isOdd
C:compare 和 isOdd
D:compare(x1,y1) 和 isOdd(lstA[i])

答案:A

第8题 有关下面代码正确的是( )。

A:checkNum() 函数定义错误。
B:将 isEven 作为 checkNum() 参数将导致错误。
C:执行后将输出 1 。
D:运行时触发异常。

答案:C

第9题 有关下面C++代码正确的是( )。

A:checkNum() 函数定义错误。
B:输出行 A 的语句将导致编译错误。
C:输出行 B 的语句将导致编译错误。
D:该代码没有编译错误。

答案:C

第10题 下面代码执行后的输出是( )。

A:4#3#2#2#4
B:4#3#2#2#1#5
C:4#3#2#1#2#4
D:4#3#2#1#2#5

答案:D

第11题 下面代码中的 isPrimeA() 和 isPrimeB() 都用于判断参数 N 是否素数,有关其时间复杂度的正确说法是( )。

A:isPrimeA() 的最坏时间复杂度是O(N), isPrimeB() 的最坏时间复杂度是O(logN), isPrimeB() 优于isPrimeA() 。
B:isPrimeA() 的最坏时间复杂度是O(N), isPrimeB() 的最坏时间复杂度是O(N1/2), isPrimeB() 优于isPrimeA() 。
C:isPrimeA() 的最坏时间复杂度是O(N1/2), isPrimeB() 的最坏时间复杂度是O(N), isPrimeA() 优于isPrimeB() 。
D:isPrimeA() 的最坏时间复杂度是O(logN), isPrimeB() 的最坏时间复杂度是O(N), isPrimeA() 优于isPrimeB()。

答案:B

第12题 下面代码用于归并排序,其中 merge() 函数被调用次数为( )。

A:0
B:1
C:6
D:7

答案:C

第13题 在上题的归并排序算法中, mergeSort(listData, start, middle); 和 mergeSort(listData, middle+ 1, end); 涉及到的算法为( )。

A:搜索算法
B:分治算法
C:贪心算法
D:递推算法

答案:B

第14题 归并排序算法的基本思想是( )。

A:将数组分成两个子数组,分别排序后再合并。
B:随机选择一个元素作为枢轴,将数组划分为两个部分。
C:从数组的最后一个元素开始,依次与前一个元素比较并交换位置。
D:比较相邻的两个元素,如果顺序错误就交换位置。

答案:A

第15题 有关下面代码的说法正确的是( )。

A:上述代码构成单向链表。
B:上述代码构成双向链表。
C:上述代码构成循环链表。
D:上述代码构成指针链表。

答案:C

二、判断题(共10题,共20分)

第16题 TCP/IP的传输层的两个不同的协议分别是UDP和TCP。

答案:正确

第17题 在特殊情况下流程图中可以出现三角框和圆形框。

答案:错误

第18题 找出自然数 N 以内的所有质数,常用算法有埃氏筛法和线性筛法,其中埃氏筛法效率更高。

答案:错误

第19题 在C++中,可以使用二分法查找链表中的元素。

答案:错误

第20题 在C++中,通过恰当的实现,可以将链表首尾相接,形成循环链表。

答案:正确

第21题 贪心算法的解可能不是最优解。

答案:正确

第22题 一般说来,冒泡排序算法优于归并排序。

答案:错误

第23题 C++语言中的 qsort 库函数是不稳定排序。

答案:正确

第24题 质数的判定和筛法的目的并不相同,质数判定旨在判断特定的正整数是否为质数,而质数筛法意在筛选出范围内的所有质数。

答案:正确

第25题 下面的C++代码执行后将输出 0 5 1 6 2 3 4 。

答案:正确

三、编程题(共2题,共50分)

第26题因数分解

第27题巧夺大奖