Logo

2025年9月 GESP C++ 1级

GESP · 1级 · 2025-09

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

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

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

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

1

⼈⼯智能现在非常⽕,小杨就想多了解一下,其中就经常听⼈提到“大模型”。那么请问这里说的“大模型”最
贴切是指 ( )。

2

小杨这学期刚开学就选修了一门编程课,然后就想编写程序来计算1到10001之间的所有偶数的和。他希望程
序采用简单累加整数的方法,同时希望源程序尽可能清晰、简洁,则下面关于实现累加时采用的主要控制结构的哪
个说法最不合适( )。

3

下面的C++代码用于输入姓名,然后输出姓名,正确的说法是( )。

string XingMing;
cout << "请输入您的姓名:";
cin >> XingMing;
cout << XingMing;
4

下列C++代码中a和b都是整型变量,执行后,其结果是( )。

a = 13;
b = 5;
cout << a / b << a %// b << a % b;
a*b;
5

C++表达式3 * 4 % 5 / 6的值是( )。

6

下面的C++代码中变量N和M都是整型,则执行时如果先输入10并输入一个制表符后输入20并回车,其输出
的数值是( )。

scanf("%d", &N);
scanf("%d", &M);
printf("{%d}",N+M);
7

当前是9月,编写C++代码求N个月后的月份。横线处应填入的代码是( )。

int N, M;
cin >> N;
M = _____________;
if (M == 0)
printf("%d个月后12月", N);
else
printf("%d个月后是%d月", N, M);
8

下面C++代码执行后的输出是( )。

int n = 0;
for (int i =0; i < 100; i++)
n += i % 2;
cout << n;
9

下面的C++代码执行后输出是( )。

int N = 0, i;
for (i = -100; i < 100; i++)
N += i % 10;
cout << N;
10

下面C++代码执行后输出是( )。

int i;
for(i = 1; i < 5; i++){
    if(i % 3 == 0)
    break;
    printf("%d#",i);
}
if(i > 5) printf("END\n");
11

下面的C++代码用于求N的镜面数(N的个位到最高位的各位数字依次反过来出现在数字中,但高位0将被忽
略,不输出),如输入1234,则将输出4321,⼜如输入120,则将输出21,错误的选项是( )。

cout << "请输入个位数不为0的正整数:";
cin >> N;
rst = 0; // 保存逆序结果
while (______________){
    rst = rst * 10 + N % 10;
    N = N / 10;
}
cout << rst << endl;
12

下面C++代码用于交换两个正整数a和b的值,不能实现交换的代码是( )。

13

下面C++代码用于获得正整数N的第M位数,约定个位数为第1位,如N等于1234,M等于2,则输出3。假设
M的值是大于等于1且小于等于N的位数。横线处应填入的代码是( )。

int N, M, div=1;
cout << "请输入一个正整数:";
cin >> N;
cout <<"请输入从右到左取第几位数:";
cin >> M;
for (int i =0; i < (M - 1); i++) div *= 10;
cout << (______________);
14

下面C++代码执行后输出是( )。

num = 0;
while (num <= 5){
    num += 1;
    if (num == 3)
    continue;
    printf("%d#", num);
}
15

下面C++代码用于记录多个输入数中的最大数和最小数(输入 -999 则输入结束),相关说法错误的是(
)。

cin >> now_num;
min_num = max_num = now_num;
while (now_num != -999){
    if (max_num < now_num)
    max_num = now_num;
    if (min_num > now_num)
    min_num = now_num;
    cin >> now_num;
}
cout << min_num << ' ' << max_num;

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

16

在集成开发环境里调试程序时,要注意不能修改源程序,因为如果修改,就要终⽌调试、关闭该文件并重新
打开,才能再次开始调试。( )

17

执行C++表达式10 % 0.5将报错,因为 0.5 所在位置只能是整数。( )

18

下面C++代码执行后将输出 9。 ( )

for (i = 0; i < 10; i++)
break;
cout << i;
19

下面C++代码执行后将输出 55。( )

n = 0;
for (int i = 0; i > -10; i--)
n = n + i * -1;
cout << n;
20

将下面C++代码中的 L1 行的i = 0修改为i = 1, 其输出与当前代码输出相同。( )

cnt = 0;
for (int i = 0; i < 100; i++) // L1
cnt += i;
cout << cnt
21

将下面C++代码中的i < 10修改为i <= 10,其执行后输出相同。( )

int n, i;
n = i = 0;
while (i < 10){
    n += i;
    i += 1;
}
cout << n;
22

下面的C++代码执行后将输出 45。( )

int n, i;
n = i = 0;
while (i < 10){
    i += 1;
    n += i;
}
cout << n;
23

执行C++代码cout << (12 + 12.12)将报错,因为 12 是 int 类型,⽽ 12.12 是 floa t类型,不同
类型不能直接运算。( )

24

下面C++代码执行时将导致无限循环(也称死循环)。( )

int count = 0;
while (count < 5){
    count += 1;
    if (count == 3)
    continue;
    cout << count << ' ';
}
25

下列C++代码用于求斐波那契数列,即第1个数为0,第2个数为1,从第三个数开始,依次是其前两个数之
和。如果输入的值为大于1的正整数,该代码能实现所求。( )

cin >> n;
a = 0, b = 1;
for (int j = 0; j < n; j++){
    cout << a << " ";
    b = b + a;
    a = b - a;
}

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

26
编程操作题 25分

试题名称:商店折扣

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

题目描述

商店正在开展促销活动,给出了两种⽅案的折扣优惠。第⼀种⽅案是购物满 元减 元;第⼆种⽅案是直接打
折,也就是说价格变为原先的 。这⾥的 均是正整数,并且 , 。

输入格式

四⾏,四个正整数 ,含义见题⽬描述。

输出格式

⼀⾏,⼀个⼩数,表⽰⼩明最少需要⽀付多少钱,保留两位⼩数。

数据范围

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

27
编程操作题 25分

试题名称:⾦字塔

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

题目描述

⾦字塔由 层⽯块垒成。从塔底向上,每层依次需要 块⽯块。请问搭建⾦
字塔总共需要多少块⽯块?

输入格式

⼀⾏,⼀个正整数 ,表⽰⾦字塔的层数。

输出格式

⼀⾏,⼀个正整数,表⽰搭建⾦字塔所需的⽯块数量。

数据范围

对于所有测试点,保证 。

已答 0/27