2025年09月GESP认证C++编程三级真题试卷

一、单选题(每题 2 分,共 30 分)
第 1 题 执行以下C++代码后, c 的数值是( )。
int a = 10, b = 3;
double c = a / b;
第 2 题 下列C++表达式的结果为 true 的是( )。
第 3 题 以下关于C++数组的说法,错误的是( )。
第 4 题 执行以下C++代码后,变量 sum 的值是( )。
int sum = 0;
for (int i = 1; i <= 5; i += 2) {
	sum += i;
	int sum=0;
}
第 5 题 要正确定义一个返回两个整数中较大值的函数 max ,应该使用( )。
第 6 题 执行以下C++代码后,数组 arr 的内容是( )。
int arr[4] = {1, 2, 3};
arr[3] = arr[0] + arr[2];
第 7 题 以下关于C++函数的描述,正确的是( )。
第 8 题 以下C++代码 count++ 执行的次数是( )。
int i = 10;
int count=0;
while (i > 0) {
	i -= 3;
	continue;
	count++;
}
第 9 题 以下C++代码段的输出是( )。
for (int i = 0; i < 4; i++) {
	for (int j = 0; j <= i; j++) {
		cout << j;
	}
	cout << "#";
}
第 10 题 以下关于C++变量作用域的说法,错误的是( )。
第 11 题 关于以下代码的说法正确的是( )。
int reversed = 0;
while (x != 0) {
	int digit = x % 10;
	x /= 10;
	reversed = reversed * 10 + digit;
}
第 12 题 以下C++代码试图查找数组中的最大值,划线处应填入( )。
#include <iostream>
using namespace std;
int findMax(int arr[], int size) {
    int maxVal = ________; // 划线处
    for (int i = 1; i < size; i++) {
        if (arr[i] > maxVal) {
            maxVal = arr[i];
        }
    }
    return maxVal;
}
第 13 题 以下关于C++函数的说法,正确的是( )。
第 14 题 以下C++代码中存在几处错误( )。
#include <iostream>
using namespace std;
int main() {
	const int SIZE = 5;
	int arr[SIZE];
	for (int i = 0; i <= SIZE; i++) {
		arr[i] = i * 2;
	}
	cout << arr[SIZE] << endl;
	return 0;
}
第 15 题 以下关于C++中 string 类和字符数组( char[] )的说法,错误的是( )。
二、判断题(每题 2 分,共 20 分)
第 1 题 表达式 sizeof('a') 的结果总是 1 ,因为 'a' 是一个字符。
第 2 题 在C++中,所有全局变量如果没有显式初始化,都会被自动初始化为0。
第 3 题 do { ... } while (false); 循环体内的语句至少会被执行一次。
第 4 题 在C++中, ++i 是一个左值表达式,而 i++ 是一个右值表达式。
第 5 题 对于 enum Color { RED, GREEN, BLUE }; , RED 的类型是 int 。
第 6 题 #define SQUARE(x) x * x 是一个安全的宏定义, SQUARE(2+3) 会正确计算出 25 。
第 7 题 在C++中, char 类型的取值范围总是 -128 到 127。
第 8 题 表达式 a > b ? a : b = 10; 一定是合法的C++代码。
第 9 题 #include "file.h" 和 #include <file.h> 在编译器查找头文件时的搜索策略是完全相同的。
第 10 题 在同一个作用域内, extern 声明的变量可以多次定义。
三、编程题(每题 25 分,共 50 分)
第 1 题 数组清零

题面描述

小 A 有一个由 $n$ 个非负整数构成的数组 $a=[a_1,a_2,\cdots,a_n]$。他会对数组$a$ 重复进行以下操作,直到数组 $n$ 只包含$0$。在一次操作中,小 A 会依次完成以下三个步骤:

1. 在数组 $a$ 中找到最大的整数,记其下标为 $K$。如果有多个最大值,那么选择其中下标最大的。

2. 从数组 $a$ 所有不为零的整数中找到最小的整数 。

3. 将第一步找出的 $a_k$ 减去 $a_j$。

例如,数组 $a=[2,3,4]$ 需要 $7$ 次操作变成 $[0,0,0]$:

$[2,3,4] \rightarrow [2,3,2] \rightarrow [2,1,2] \rightarrow [2,1,1] \rightarrow [1,1,1] \rightarrow [1,1,0] \rightarrow [1,0,0] \rightarrow [0,0,0]$

小 A 想知道,对于给定的数组 $a$,需要多少次操作才能使得 $a$中的整数全部变成 $0$。可以证明,$a$ 中整数必然可以在

有限次操作后全部变成 $0$。你能帮他计算出答案吗?

输入格式

第一行,一个正整数 $n$,表示数组 $a$ 的长度。

第二行,$n$ 个非负整数 $a_1,a_2,\cdots,a_n$,表示数组 $a$ 中的整数。

输出格式

一行,一个正整数,表示 $a$ 中整数全部变成 $0$ 所需要的操作次数。

输入数据#1 复制
3
2 3 4
输出数据#1 复制
7
输入数据#2 复制
5
1 3 2 2 5
输出数据#2 复制
13

数据要求

对于所有测试点,保证 $1 \le n \le 100$,$0 \le a_i \le 100$ 。

第 2 题 日历制作

题面描述

小A想制作2025年每个月的日历。他希望你能编写一个程序,按照格式输出给定月份的日历。

具体来说,第一行需要输出 MON TUE WED THU FRI SAT SUN ,分别表示星期一到星期日。接下来若干行中依次输出这个月所包含的日期,日期的个位需要和对应星期几的缩写最后一个字母对齐。例如,2025 年 9 月 1 日是星期

一,在输出九月的日历时,1 号的个位 1 就需要与星期一 MON 的最后一个字母 N 对齐。九月的日历输出效果如下:

MON TUE WED THU FRI SAT SUN

1 2 3 4 5 6 7

8 9 10 11 12 13 14

15 16 17 18 19 20 21

22 23 24 25 26 27 28

29 30

你能帮助小 A 完成日历的制作吗?

输入格式

一行,一个正整数 ,表示需要按照格式输出 2025 年 $m$ 月的日历。

输出格式

输出包含若干行,表示 2025 年 $m$ 月的日历。

输入数据#1 复制
9
输出数据#1 复制
MON TUE WED THU FRI SAT SUN
  1   2   3   4   5   6   7
  8   9  10  11  12  13  14
 15  16  17  18  19  20  21
 22  23  24  25  26  27  28
 29  30
输入数据#2 复制
6
输出数据#2 复制
MON TUE WED THU FRI SAT SUN
                          1
  2   3   4   5   6   7   8
  9  10  11  12  13  14  15
 16  17  18  19  20  21  22
 23  24  25  26  27  28  29
 30

数据要求

对于所有测试点,保证 $1 \le m \le 12$。