2025年12月 GESP C++ 8级认证考试真题(含编程操作题部分)
选 单选题(共 15 题,每题 2 分)
某平台生成“取件码”由6个字符组成:前4位为数字(0–9),后2位为大写字母(A–Z),其中字母不能
为 I、O。假设数字和字母均可重复使用,要求整个取件码中恰好有2个数字为奇数。共有多少种不同取件码?(
)
下列代码实现了归并排序(Merge Sort)的分治部分。为了正确地将数组 a 的 [left, right] 区间进行
排序,横线处应该填入的是( )。
void merge_sort(int a[], int left, int right) {
if (left >= right) return;
int mid = (left + right) / 2;
merge_sort(a, left, mid);
________; // 在此处填入选项
merge(a, left, mid, right); // 合并操作
}
某社团有男生8⼈、⼥生7⼈。现需选出1名队长(性别不限)、1名副队长(性别不限)、2名宣传委员(两
⼈无角色区别,且必须至少1名⼥生)。假如一⼈不能兼任多职,共有多少种不同选法?( )
二项式 的展开式中 项的系数为( )。
下面是使用邻接矩阵实现的Dijkstra算法的核心片段,用于求单源最短路径。在找到当前距离起点最近的顶点
u 后,需要更新其邻接点 j 的距离。横线处应填入的代码是( )。
for (int j = 1; j <= n; j++) {
if (!visited[j] && graph[u][j] < INF) {
if (________) { // 在此处填入选项
dis[j] = dis[u] + graph[u][j];
}
}
}
下面程序使用动态规划求两个字符串的最长公共⼦序列(LCS)长度,横线处应填入的是( )。
#include <algorithm>
#include <string>
#include <vector>
using namespace std;
int lcs_len(const string &a, const string &b) {
int n = (int)a.size(), m = (int)b.size();
vector<vector<int>> dp(n + 1, vector<int>(m + 1, 0));
for (int i = 1; i <= n; i++)
for (int j = 1; j <= m; j++)
if (a[i - 1] == b[j - 1])
dp[i][j] = dp[i - 1][j - 1] + 1;
else
________; // 在此处填入选项
return dp[n][m];
}
已知两个点 和 在平面直角坐标系中的坐标。下列C++表达式中,能正确计算这两点之间
直线距离的是( )。
已知 int a = 10;,执行 int &b = a; b = 20; 后,变量 a 的值是( )。
下列代码的时间复杂度(以 为自变量,忽略常数与低阶项)是( )。
long long s = 0;
for (int i = 1; i <= n; i++) {
for (int j = 1; j * j <= i; j++) {
s += j;
}
}
下列程序实现了线性筛法(欧拉筛),用于在 时间内求出 之间的所有质数。为了保证每个合数
只被其最小质因⼦筛掉,横线处应填入的语句是( )。
for (int i = 2; i <= n; i++) {
if (!not_prime[i]) primes[++cnt] = i;
for (int j = 1; j <= cnt && i * primes[j] <= n; j++) {
not_prime[i * primes[j]] = true;
if (________) break; // 在此处填入选项
}
}
在C++语⾔中,关于类的继承和访问权限,下列说法正确的是( )。
当输入 6 时,下列程序的输出结果为( )。
#include <iostream>
using namespace std;
int f(int n) {
if (n <= 3) return n;
return f(n - 1) + f(n - 2) + 2 * f(n - 3);
}
int main() {
int n;
cin >> n;
cout << f(n) << endl;
return 0;
}
从1到999这999个正整数中,十进制表⽰中数字 5 恰好出现一次的数有多少个?( )
当输入 2023 时,下列程序的输出结果为( )。
#include <iostream>
using namespace std;
int main() {
int x, ans = 0;
cin >> x;
while (x != 0) {
x -= x & -x;
ans++;
}
cout << ans << endl;
return 0;
}
对连通无向图执行Kruskal算法。已按边权从小到大依次扫描到某条边 。此时在已经构建的部分
MST结构中, 已在同一连通块内。关于边 的处理,下列说法正确的是( )。
判 判断题(共 10 题,每题 2 分)
若一项任务可用两种互斥方案完成:方案A有 种做法,方案B有 种做法,则总做法数为 。
在C++语⾔中,引用一旦被初始化,就不能再改为引用另一个变量。
快速排序和归并排序的平均时间复杂度都是 ,但快速排序是不稳定的排序算法,归并排序是稳定
的排序算法。
使用 math.h 或 cmath 头文件中的函数,表达式 sqrt(4) 的结果类型为 double。
在杨辉三角形中,第 行(从0开始计数,即第 行有 个数)的所有数字之和等于 。
使用二叉堆优化的Dijkstra最短路算法,在某些特殊情况下时间复杂度不如朴素实现的 。
个不同元素依次入栈的出栈序列数与将 个不同元素划分成若⼲非空⼦集的方案数相等。
快速排序在最坏情况下的时间复杂度为 ,可以通过随机化选择基准值(pivot)的方法完全避免退
化。
在C++语⾔中,一个类可以拥有多个构造函数,也可以拥有多个析构函数。
求两个序列的最长公共⼦序列(LCS)时,使用滚动数组优化空间后,仍然可以还原出具体的LCS序列。
编 编程操作题(共 2 题,共 50 分)
试题名称:猫和⽼⿏
时间限制:1.0 s | 内存限制:512.0 MB
题目描述
猫和⽼⿏所在的庄园可以视为⼀张由 个点和 条带权⽆向边构成的连通图。结点依次以 编号,结点
( )有价值为 的奶酪。在 条带权⽆向边中,第 ( )条⽆向边连接结点 与结点 ,边权
表⽰猫和⽼⿏通过这条边所需的时间。
猫窝位于结点 ,⽼⿏洞位于结点 。对于⽼⿏⽽⾔,结点 是安全的当且仅当:
⽼⿏能规划⼀条从结点 出发逃往⽼⿏洞的路径,使得对于路径上任意结点 (包括结点 与⽼⿏洞)都有:
猫从猫窝出发到结点 的最短时间严格⼤于⽼⿏从结点 沿这条路径前往结点 所需的时间。
⽼⿏在拿取安全结点的奶酪时不存在被猫抓住的可能,但在拿取不是安全结点的奶酪时则不⼀定。为了确保万⽆⼀
失,⽼⿏决定只拿取安全结点放置的奶酪。请你计算⽼⿏所能拿到的奶酪价值之和。
输入格式
第⼀⾏,两个正整数 ,分别表⽰图的结点数与边数。
第⼆⾏,两个正整数 ,分别表⽰猫窝的结点编号,以及⽼⿏洞的结点编号。
第三⾏, 个正整数 ,表⽰各个结点的奶酪价值。
接下来 ⾏中的第 ⾏( )包含三个正整数 ,表⽰图中连接结点 与结点 的边,边权为 。
输出格式
输出⼀⾏,⼀个整数,表⽰⽼⿏所能拿到的奶酪价值之和。
数据范围
对于 的测试点,保证 , 。
对于所有测试点,保证 , , 且 , , 。
试题名称:宝⽯项链
时间限制:1.0 s | 内存限制:512.0 MB
题目描述
⼩ A 有⼀串包含 枚宝⽯的宝⽯项链,这些宝⽯按照在项链中的顺序依次以 编号,第 枚宝⽯与第 枚
宝⽯相邻。项链由 种宝⽯组成,其中第 枚宝⽯种类为 。
⼩ A 想将宝⽯项链分给他的好朋友们。具体⽽⾔,⼩ A 会将项链划分为若⼲连续段,并且需要保证每段都包含全部
种宝⽯。请帮⼩ A 计算在满⾜条件的前提下,宝⽯项链最多可以划分为多少段。
输入格式
第⼀⾏,两个正整数 ,分别表⽰宝⽯项链中的宝⽯的数量与种类数。
第⼆⾏, 个正整数 ,表⽰每枚宝⽯的种类。
输出格式
输出⼀⾏,⼀个整数,表⽰宝⽯项链最多可以划分的段数。
数据范围
对于 的测试点,保证 。
对于所有测试点,保证 , , ,保证 均在 中出现。