GESP C++ 一级 2025年09月真题解析

GESP C++ 一级 2025年09月真题解析

选择题(每题 2 分,共 30 分)


第1题

题目:

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

选项:

A. 大电脑模型

B. 大规模智能

C. 智能的单位

D. 大语言模型

答案: D

解析:

"大模型"通常指的是参数规模巨大的深度学习模型,尤其是大语言模型 (如GPT、BERT等),因此选 D。


第2题

题目:

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

选项:

A. 使用循环结构

B. 使用循环和分支的组合

C. 仅使用顺序结构

D. 不使用分支结构

答案: C

解析:

累加1到10001的偶数必须使用循环结构,不能仅用顺序结构完成,因此 C 最不合适。


第3题

题目:

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

cpp 复制代码
string XingMing;
cout << "请输入您的姓名:";
cin >> XingMing;
cout << XingMing;

选项:

A. XingMing 是汉语拼音,不能作为变量名称

B. 可以将 XingMing 改为 Xing Ming

C. 可以将 XingMing 改为 xingming

D. 可以将 XingMing 改为 Xing-Ming

答案: C

解析:
C++变量名区分大小写,但不能有空格或连字符,因此只有 C 合法。


第4题

题目:

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

cpp 复制代码
a = 13;
b = 5;
cout << a / b << a %// b << a % b;
a*b;

选项:

A. 2 3

B. 23

C. 20

D. 以上都不准确

答案: C

解析:
第三行//后边的内容被注释,程序执行时不会执行,接着执行第4行,所以三、四行相当于cout << a / b << a % a * b;13 / 5为2,a % a * b先计算a % a值为0,再计算0 * b值为0,所以输出为20


第5题

题目:

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

选项:

A. 10

B. 5

C. 2

D. 0

答案: D

解析:
运算顺序从左到右:3*4=1212%5=22/6=0(整数除法),结果为 0。


第6题

题目:

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

cpp 复制代码
scanf("%d", &N);
scanf("%d", &M);
printf("{%d}", N + M);

选项:

A. {30}

B. 1020

C. {N+M}

D. 不输出,继续等待输入

答案: A

解析:
scanf 会自动跳过空白字符(包括制表符),正确读入两个整数并输出 {30}


第7题

题目:

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

cpp 复制代码
int N, M;
cin >> N;
M = _____________;
if (M == 0)
    printf("%d个月后12月", N);
else
    printf("%d个月后是%d月", N, M);

选项:

A. N % 12

B. 9 + N % 12

C. (9 + N) / 12

D. (9 + N) % 12

答案: D

解析:
当前是9月,N个月后应为 (9 + N) % 12,若结果为0表示12月。


第8题

题目:

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

cpp 复制代码
int n = 0;
for (int i = 0; i < 100; i++)
    n += i % 2;
cout << n;

选项:

A. 5050

B. 4950

C. 50

D. 49

答案: C

解析:
i % 2 在 i 为奇数时为1,偶数时为0,循环100次,奇数有50个,所以 n = 50。


第9题

题目:

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

cpp 复制代码
int N = 0, i;
for (i = -100; i < 100; i++)
    N += i % 10;
cout << N;

选项:

A. 900

B. 100

C. 0

D. -100

答案: C

解析:
i % 10 是对称的,-100 到 99 的个位数之和为0,因此 N = 0。


第10题

题目:

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

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

选项:

A. 1#2#

B. 1#2#END

C. 1#2

D. 1#2#3#4#END

答案: A

解析:
循环在 i=3 时跳出,只输出 1#2#,i=3 不大于5,不输出 END。


第11题

题目:

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

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

选项:

A. N != 0

B. not (N == 0)

C. N = 0

D. N > 0

答案: C

解析:
C 选项是赋值语句,不是条件判断,会导致死循环或逻辑错误。


第12题

题目:

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

选项:

A.

cpp 复制代码
cout << "输入第一个正整数:";
cin >> a;
cout << "输入第二个正整数:";
cin >> b;
temp = a;
a = b;
b = temp;
cout << "a=" << a << " b=" << b << endl;

B.

cpp 复制代码
cout << "输入第一个正整数:";
cin >> a;
cout << "输入第二个正整数:";
cin >> b;
b = a - b;
a = a - b;
b = a + b;
cout << "a=" << a << " b=" << b << endl;

C.

cpp 复制代码
cout << "输入第一个正整数:";
cin >> a;
cout << "输入第二个正整数:";

cin >> b;
a = a + b;
b = a - b;
a = a - b;
cout << "a=" << a << " b=" << b << endl;

D.

cpp 复制代码
cout << "输入第一个正整数:";
cin >> a;
cout << "输入第二个正整数:";
cin >> b;
a, b = b, a;
cout << "a=" << a << " b=" << b << endl;

答案: D

解析:
A. 使用临时变量 temp 实现交换(正确)
B. 使用加减法实现交换(正确)
C. 使用加减法实现交换(正确)
D. C++ 不支持 Python 风格的元组赋值,a, b = b, a; 是无效语法。


第13题

题目:

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

cpp 复制代码
int N, M, div = 1;
cout << "请输入一个正整数:";
cin >> N;
cout << "请输入从右到左取第几位数:";
cin >> M;

for (int i = 0; i < (M - 1); i++) div *= 10;

cout << (______________);

选项:

A. N % div / 10

B. N / div / 10

C. N % div % 10

D. N / div % 10

答案: D

解析:
先除以 div 去掉低位,再 %10 取当前位。


第14题

题目:

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

cpp 复制代码
num = 0;
while (num <= 5) {
    num += 1;
    if (num == 3)
        continue;
    printf("%d#", num);
}

选项:

A. 1#2#4#5#6#

B. 1#2#4#5#6

C. 1#2#3#4#5#6#

D. 1#2#3#4#5#6

答案: A

解析:
跳过 num==3 的打印,输出为 1#2#4#5#6#,注意最后的 # 是格式要求。


第15题

题目:

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

cpp 复制代码
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;

选项:

A. 程序运行时如果第一个数输入-999,则输出将是-999 -999

B. 程序输入过程中,如果输入的第一个数不是-999,则如果待输入的数据中没有-999,则程序能求出已输入整数中的最大数和最小数

C. 如果用于输入考试成绩,即成绩中不可能有-999,则程序能求出已输入成绩中的最高成绩和最低成绩

D. 可以将 cin >> now_num; 移动到 while (now_num != -999){ 下面,结果不变

答案: D

解析:
D 错误,移动后会导致第一个输入未处理,逻辑出错。


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


第1题

题目:

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

答案: ×

解析:
现代 IDE 支持调试时修改代码并继续调试,无需关闭文件。


第2题

题目:

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

答案:

解析:
% 运算符要求两个操作数都是整数,0.5 是浮点数,编译报错。


第3题

题目:

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

cpp 复制代码
for (i = 0; i < 10; i++)
    break;
cout << i;

答案: ×

解析:
循环第一次就 break,i = 0,输出为0。


第4题

题目:

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

cpp 复制代码
n = 0;
for (int i = 0; i > -10; i--)
    n = n + i * -1;
cout << n;

答案: ×

解析:

循环从 i = 0 开始,到 i = -9 结束,共执行 10 次。每次循环中,i * -1 的值依次为 0, 1, 2, 3, 4, 5, 6, 7, 8, 9。累加后总和为 45,因此程序输出为 45


第5题

题目:

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

cpp 复制代码
cnt = 0;
for (int i = 0; i < 100; i++) //L1
    cnt += i;
cout << cnt;

答案:

解析:
从0或1开始累加不影响总和,输出相同。


第6题

题目:

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

cpp 复制代码
int n, i;
n = i = 0;
while (i < 10) {
    n += i;
    i += 1;
}
cout << n;

答案: ×

解析:
修改后多循环一次,i=10 也参与累加,结果不同。


第7题

题目:

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

cpp 复制代码
int n, i;
n = i = 0;
while (i < 10) {
    i += 1;
    n += i;
}
cout << n;

答案: ×

解析:
累加1到10,结果为55,题目说输出45是错误的。


第8题

题目:

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

答案: ×

解析:
C++支持自动类型提升,int 与 float 可混合运算,不会报错。


第9题

题目:

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

cpp 复制代码
int count = 0;
while (count < 5) {
    count += 1;
    if (count == 3)
        continue;
    cout << count << ' ';
}

答案: ×

解析:
count 正常递增,循环会正常结束,不会死循环。


第10题

题目:

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

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

答案:

解析:
该代码正确实现了斐波那契数列的输出逻辑。


相关推荐
iiiiii112 小时前
【论文阅读笔记】多实例学习方法 Diverse Density(DD):在特征空间中寻找正概念的坐标
论文阅读·人工智能·笔记·机器学习·ai·学习方法·多实例学习
GOTXX2 小时前
用Rust实现一个简易的rsync(远程文件同步)工具
开发语言·后端·rust
诸葛亮的芭蕉扇2 小时前
抓图巡检-底图支持绘制
开发语言·前端·javascript
喵个咪3 小时前
Qt 优雅实现线程安全单例模式(模板化 + 自动清理)
c++·后端·qt
止水编程 water_proof4 小时前
JavaScript基础
开发语言·javascript·ecmascript
欧阳x天4 小时前
C++入门(一)
c++
小张成长计划..4 小时前
【C++】:priority_queue的理解,使用和模拟实现
c++
小小测试开发4 小时前
JMeter JSR223预处理程序高级用法:解锁自动化测试的灵活性上限
开发语言·jmeter·groovy