Logo

2025年9月 GESP C++ 3级

GESP · 3级 · 2025-09

60:00
满分 100
时长 60 分钟
27

2025年9月 GESP C++ 3级认证考试真题(含编程操作题部分)

答题卡 已答 0/27
已答 正确 错误 编程题

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

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[])的说法,错误的是( )。

判断题(共 10 题,每题 2 分)

16

表达式 sizeof('a') 的结果总是 1,因为 'a' 是一个字符。

17

在C++中,所有全局变量如果没有显式初始化,都会被自动初始化为0。

18

do { ... } while (false); 循环体内的语句至少会被执行一次。

19

在C++中,++i 是一个左值表达式,⽽ i++ 是一个右值表达式。

20

对于 enum Color { RED, GREEN, BLUE };,RED 的类型是 int

21

#define SQUARE(x) x * x 是一个安全的宏定义,SQUARE(2+3) 会正确计算出 25。

22

在C++中,char 类型的取值范围总是 -128 到 127。

23

表达式 a > b ? a : b = 10; 一定是合法的C++代码。

24

#include "file.h" 和 #include <file.h> 在编译器查找头文件时的搜索策略是完全相同的。

25

在同一个作用域内,extern 声明的变量可以多次定义。

编程操作题(共 2 题,共 50 分)

26
编程操作题 25分

试题名称:数组清零

时间限制:1.0 s | 内存限制:512.0 MB

题目描述

⼩ A 有⼀个由 个⾮负整数构成的数组 。他会对数组 重复进⾏以下操作,直到数组 只包含
。在⼀次操作中,⼩ A 会依次完成以下三个步骤:

  1. 在数组 中找到最⼤的整数,记其下标为 。如果有多个最⼤值,那么选择其中下标最⼤的。
  2. 从数组 所有不为零的整数中找到最⼩的整数 。
  3. 将第⼀步找出的 减去 。
    例如,数组 需要 次操作变成 :
    ⼩ A 想知道,对于给定的数组 ,需要多少次操作才能使得 中的整数全部变成 。可以证明, 中整数必然可以在
    有限次操作后全部变成 。你能帮他计算出答案吗?

输入格式

第⼀⾏,⼀个正整数 ,表⽰数组 的长度。
第⼆⾏, 个⾮负整数 ,表⽰数组 中的整数。

输出格式

⼀⾏,⼀个正整数,表⽰ 中整数全部变成 所需要的操作次数。

数据范围

对于所有测试点,保证 , 。

27
编程操作题 25分

试题名称:⽇历制作

时间限制:1.0 s | 内存限制:512.0 MB

题目描述

⼩ A 想制作 2025 年每个⽉的⽇历。他希望你能编写⼀个程序,按照格式输出给定⽉份的⽇历。
具体来说,第⼀⾏需要输出 MON TUE WED THU FRI SAT SUN,分别表⽰星期⼀到星期⽇。接下来若⼲⾏中依次输
出这个⽉所包含的⽇期,⽇期的个位需要和对应星期⼏的缩写最后⼀个字母对齐。例如,2025 年 9 ⽉ 1 ⽇是星期
⼀,在输出九⽉的⽇历时,1 号的个位 1 就需要与星期⼀ MON 的最后⼀个字母 N 对齐。九⽉的⽇历输出效果如
下:
1 MON TUE WED THU FRI SAT SUN
2 1 2 3 4 5 6 7
3 8 9 10 11 12 13 14
4 15 16 17 18 19 20 21
5 22 23 24 25 26 27 28
6 29 30
你能帮助⼩ A 完成⽇历的制作吗?

输入格式

⼀⾏,⼀个正整数 ,表⽰需要按照格式输出 2025 年 ⽉的⽇历。

输出格式

输出包含若⼲⾏,表⽰ 2025 年 ⽉的⽇历。

数据范围

对于所有测试点,保证 。

已答 0/27