GESP 2025年6月_C++五级试卷
从PDF导入:GESP 2025年6月_C++五级试卷
C++
180分钟
总分 100.0
27 题
试卷题目预览
第1题
中级
2.0分
单选
与数组相比,链表在( )操作上通常具有更高的效率。
第2题
中级
2.0分
单选
下面C++代码实现双向链表。函数is_empty()判断链表是否为空,如链表为空返回true,否则返回false。横线处不能填写( )。

第3题
中级
2.0分
单选
基于上题代码正确的前提下,填入相应代码完善append(),用于在双向链表尾部增加新节点,横线上应填写( )。

第4题
中级
2.0分
单选
下列C++代码用循环链表解决约瑟夫问题,即假设n个人围成一圈,从第一个人开始数,每次数到第k个的人就出圈,输出最后留下的那个人的编号。横线上应填写( )。
第5题
中级
2.0分
单选
下列C++代码判断一个正整数是否是质数,说法正确的是( )。
第6题
中级
2.0分
单选
下列C++代码用两种方式求解两个正整数的最大公约数,说法错误的是( )。
第7题
中级
2.0分
单选
下面的代码用于判断整数是否是质数,错误的说法是( )。
第8题
中级
2.0分
单选
唯一分解定理描述了关于正整数的什么性质?
第9题
中级
2.0分
单选
下面的C++代码,用于求一系列数据中的最大值。有关其算法说法错误的是( )。

第10题
中级
2.0分
单选
下面的C++代码,用于求一系列数据中的最大值。有关其算法说法错误的是( )。

第11题
中级
2.0分
单选
下面的C++代码用于在升序数组lst中查找目标值target最后一次出现的位置。相关说法,正确的是( )。
第12题
中级
2.0分
单选
有关下面C++代码的说法,错误的是( )。
第13题
中级
2.0分
单选
硬币找零问题中要求找给客户最少的硬币。coins存储可用硬币规格,单位为角,假设规格都小于10角,且一定有1角规格。amount为要找零的金额,约定必须为1角的
第14题
中级
2.0分
单选
关于下述C++代码的快速排序算法,说法错误的是( )。
第15题
中级
2.0分
单选
小杨编写了一个如下的高精度除法函数,则横线上应填写的代码为( )。
第16题
中级
2.0分
判断
下面C++代码是用欧几里得算法(辗转相除法)求两个正整数的最大公约数,a大于b还是小于b都适用。

第17题
中级
2.0分
判断
假设函数gcd()函数能正确求两个正整数的最大公约数,则下面的lcm()函数能求相应两数的最小公倍数。

第18题
中级
2.0分
判断
下面的C++代码用于输出每个数对应的质因数列表。
第19题
中级
2.0分
判断
下面的C++代码实现归并排序。代码在执行时,将输出一次HERE字符串,因为merge()函数仅被调用一次。
第20题
中级
2.0分
判断
归并排序的最好、最坏和平均时间复杂度均为O(n log n)。
第21题
中级
2.0分
判断
查字典这个小学生必备技能,可以把字典视为一个已排序的数组。这种查字典的一系列操作可看作二分查找。
第22题
中级
2.0分
判断
求解最短路径问题常用Dijkstra算法,从算法的描述可以看出,Dijkstra算法是贪心算法。
第23题
中级
2.0分
判断
分治算法将原问题可以分解成规模更小的子问题,但由于分治算法需要将问题进行分解,所以分治算法的效率通常比直接求解原问题的效率低。
第24题
中级
2.0分
判断
函数puzzle定义如下,则调用puzzle(7)程序会无限递归。

第25题
中级
2.0分
判断
如下为线性筛法,用于高效生成素数表,其核心思想是每个合数只被它的最小质因数筛掉一次,时间复杂度为O(n)。
第26题
中级
25.0分
编程
奖品兑换
班主任给上课专心听讲、认真完成作业的同学们分别发放了若干张课堂优秀券和作业优秀券。同学们可以使用这两种券找班主任兑换奖品。具体来说,可以使用a张课堂优秀券和b张作业优秀券兑换一份奖品,或者使用c张课堂优秀券和d张作业优秀券兑换一份奖品。 现在小A有n张课堂优秀券和m张作业优秀券,他最多能兑换多少份奖品呢?
【输入格式】
第一行,两个正整数n, m,分别表示小A持有的课堂优秀券和作业优秀券的数量。 第二行,两个正整数a, b,表示兑换一份奖品所需的两种券的数量。
【输出格式】
输出共一行,一个整数,表示最多能兑换的奖品份数。
【样例输入】 8 8 2 1 【样例输出】 5 对于50%的测试点,保证n,m<=1000,a,b<=100。 对于所有测试点,保证1<=n,m<=10^9,1<=a,b<=10^5。
第27题
中级
25.0分
编程
最大公因数
对于两个正整数x,y,它们的最大公因数记为gcd(x,y)。对于n个正整数a1,a2,...,an,它们的最大公因数为:gcd(a1,a2,...,an) = gcd(gcd(...gcd(gcd(a1,a2),a3)...),an)。 给定n个正整数a1,a2,...,an以及q组询问。对于第i(1<=i<=q)组询问,请求出gcd(a1+i, a2+i, ..., an+i)。
【输入格式】
第一行,两个正整数n, q,分别表示给定正整数的数量,以及询问组数。 第二行,n个正整数a1,a2,...,an。
【输出格式】
输出共q行,第i行包含一个正整数,表示gcd(a1+i, a2+i, ..., an+i)。
【样例输入】 5 3 6 9 12 18 30 【样例输出】 1 3 1 对于50%的测试点,保证n,q<=5000,ai,q<=10^4。 对于所有测试点,保证n,q<=10^5,1<=ai<=10^9,1<=q<=10^5。