#1464. GESP-C++二级(2025-06)
GESP-C++二级(2025-06)
CCF GESP C++ 二级 (2025 年 06 月)
一、单选题(每题 2 分,共 30 分)
第 1 题 2025 年 4 月 19 日在北京举行了一场颇为瞩目的人形机器人半程马拉松赛。比赛期间,跑动着的机器人会利用身上安装的多个传感器所反馈的数据来调整姿态、保持平衡等,那么这类传感器类似于计算机的 ( )。
{{ select(1) }}
- 处理器
- 存储器
- 输入设备
- 输出设备
第 2 题 小明购置的计算机使用一年后觉得内存不够用了,想购置一个容量更大的内存条,这时他需要的内存条是 ( )。
{{ select(2) }}
- RAM
- ROM
- CACHE
- EPROM
第 3 题 下面 C++ 代码执行后的输出是 ( )。
int a=3; float b = 3.5;
cout << (a *= b);
{{ select(3) }}
- 3
- 3.5
- 10
- 11
第 4 题 下面 C++ 代码用于获得正整数的第 3 位数,如 1234 则输出 2。如果是一位数或两位数,则输出 0。横线处应填入的代码是 ( )。
int N, remainder;
cout << "请输入正整数:";
cin >> N;
cout <<_______________;
{{ select(4) }}
- N % 1000 / 100
- N / 1000 % 100
- N / 1000 / 100
- N % 100 / 100
第 5 题 下面 C++ 代码执行,其输出是 ( )。
int a, b = (6, 28);
b == a;
a = b;
cout << a << ' ' << b;
{{ select(5) }}
- 6 28
- 6 6
- 28 6
- 28 28
第 6 题 今天星期六,其后第 N 天星期几?如果是星期一到星期六输出形如:星期 1、星期 2 等,星期天则输出星期天。下面的 C++ 代码用于完成上述要求,横线处应填上的代码是 ( )。
int N, remainder;
cin >> N;
remainder = ______________;
if(remainder == 0)
printf("星期六后第%d天是星期天\n", N);
else
printf("星期六后第%d天是星期%d\n", N, remainder);
{{ select(6) }}
- (N + 6) / 7
- (N + 6) // 7
- N % 7
- (N + 6) % 7
第 7 题 下面的 C++ 代码执行后其输出是 ( )。
int i, Sum = 0;
for (i = 1; i < 10; i++){
Sum += i;
if(i % 2) continue;
if(i % 7) break;
}
cout << Sum;
{{ select(7) }}
- 45
- 28
- 3
- 0
第 8 题 下面 C++ 代码执行后其输出是 ( )。
int i, j;
for(i = 1; i < 12; i++)
for(j = 1; j < i; j++)
if(i * j % 2 == 1)
break;
cout << i * j;
{{ select(8) }}
- 110
- 22
- 12
- 3
第 9 题 下面 C++ 代码执行后输出是 ( )。
int i, cnt = 0;
for(i = -99; i < 100; i += 2)
cnt = 1 + cnt;
cout << cnt;
{{ select(9) }}
- 101
- 100
- 99
- 98
第 10 题 下面 C++ 代码执行后输出是 ( )。
int i;
for(i = 1; i < 10; i++){
if(i % 3 != 0){
printf("A#");
continue;
}
else
break;
printf("0#");
}
if(i == 10) cout << "1";
{{ select(10) }}
- A#A#
- A#0#A#0
- A#A#1
- A#0#A#0#1
第 11 题 下面 C++ 代码执行后的输出是 ( )。
int i,j;
for(i = 0; i < 3; i++)
for(j = 0; j < i; j++)
printf("%d#%d-", i, j);
printf("END");
{{ select(11) }}
- 0#0-1#0-2#0-2#1-END
- 0#0-1#0-1#1-2#0-2#1-2#2-3#0-3#1-3#2-END
- 0#0-1#0-1#1-2#0-2#1-2#2-END
- 1#0-2#0-2#1-END
第 12 题 下面 C++ 代码执行后,将输出不能被 3 整除且除以 5 余数为 2 的数。下列选项不能实现的是 ( )。
for(i = 0; i < 100; i++) int i,j;
if(___________________)
cout << i << endl;
{{ select(12) }}
- (i % 3 != 0) && (i % 5 == 2)
- (i % 3) && (i % 5 == 2)
- (i % 3) && !(i % 5 != 2)
- !(i % 3) && (i % 5 == 2)
第 13 题 下面 C++ 代码用于判断一个大于 0 的正整数是几位数,横线处应填入代码先后是 ( )。
int N, cnt;
cout << "请输入大于0的正整数:";
cin >> N;
cnt = 0;
while (________){
cnt += 1;
______________;
}
cout << cnt;
1,
N > 1
N = N / 10
2,
N > 1
N /= 10
3,
N == 0
N /= 10
4,
N > 0
N /= 10
{{ select(13) }}
- 1
- 2
- 3
- 4
第 14 题 判断一个数是否为自守数。自守数的定义是如果一个数的平方其尾数与该数相同,则为自守数,如25的平方是 625, 其尾数是 25, 所以 25 是自守数。相关说法错误的是 ()
int N, N1, M1;
cout << "输入一个正整数:";
cin >> N;
N1 = N, M1 = N * N;
bool Flag = true;
while (N1 > 0){
if (N1 % 10 != M1 % 10){
Flag = false;
break;
}
else{
N1 = N1 / 10, M1 = M1 / 10;
}
}
if (Flag == true)
printf("%d的平方是%d,是自守数", N, N * N);
else
printf("%d的平方是%d,不是自守数", N, N * N);
{{ select(14) }}
- 如果 Flag 在循环中不被改为 false, 则说明该数是自守数
- 代码 if (N1 % 10 != M1 % 10) 用于判断其个位数是否相等,如果不等,则表明不是自守数
- 代码 N1 = N1 / 10, M1 = M1 / 10 将个位数去掉
- 将 N1 > 0 改为 N > 0 效果相同
第 15 题 下面 C++ 代码实现输出如下图形,相关说法的是 (错误)。
请输入层数: 10
0
12
345
6789
01234
567890
1234567
89012345
678901234
5678901234
int line_number, now_number;
int i,row;
cout << "请输入行数: ";
cin >> line_number;
now_number = 0;
for (row = 1; row < line_number + 1; row++){ // L1
for (i = 0; i < row; i++){ // L2
cout << now_number;
now_number += 1;
if (now_number == 10) now_number = 0; // L3
}
cout << endl;
}
{{ select(15) }}
- 代码 now_number = 0 移动到 L1 和 L2 标记的两行代码之间,效果维持不变
- 代码 now_number += 1 修改为 now_number = 1 + now_number 效果维持不变
- 将代码 now_number == 10 调整为 now_number > 9 效果维持不变
- 将最后一行的 cout << endl 修改为 cout << "\n" , 效果维持不变
2 判断题 (每题 2 分,共 20 分)
第 1 题 人们现在参加很多闭卷考试时通常都不允许带智能手机、平板电脑等,此外很多种智能手表同样因为具有嵌入操作系统及通信等功能,所以也不允许随身携带。( )
{{ select(16) }}
- 对
- 错
第 2 题 在 C++ 代码中,假设 N 为正整数,则 N / 10 舍弃个位数。如果 N 小于 10, 则其值为 0, 大于 10 则是舍弃个位数的数。( )
{{ select(17) }}
- 对
- 错
第 3 题 下列 C++ 代码执行后,其输出为 10 20 , 即 a == b 和 b == a 对 a 和 b 的值没有任何影响。( )
{{ select(18) }}
- 对
- 错
int a = 10, b = 20;
a == b;
b == a;
cout << (a, b);
第 4 题 a 和 b 分别是 C++ 的整型变量,如果表达式 max (a, b) == min (a, b) 的值为真,则说明 a 和 b 相等。
{{ select(19) }}
- 对
- 错
第 5 题 下面 C++ 代码编译时将报错,因为字符变量 a 被赋值了浮点值。 ( )
char a = '1';
a = 45.6;
cout << a;
{{ select(20) }}
- 对
- 错
第 6 题 下面 C++ 代码执行时如输入 59.99, 将输出及格两个汉字。()
{{ select(21) }}
- 对
- 错
int score;
cout << "请输入学生成绩: ";
cin >> score;
if (score < 60)
cout << "不及格";
else
cout << "及格";
第 7 题 在下面的 C++ 代码中,因为 continue 将被执行,因此不会有输出。( )
{{ select(22) }}
- 对
- 错
int i;
for (i = 1; i < 10; i++)
if (i % 2 == 0)
continue;
if(i == 10)
cout << "END";
第 8 题 下面的 C++ 代码执行后将输出 15
{{ select(23) }}
- 对
- 错
int Sum = 0;
for (int i = 0; i < 5; i++)
Sum += i;
cout << Sum;
第 9 题 将下面 C++ 代码中的 (int i = 5; i> 1; i--) 调整为 (int i = 1; i < 5; i++) 输出结果相同,因为 5 到 1 与 1 到 5 的求和相同。( )
{{ select(24) }}
- 对
- 错
int tnt;
tnt = 0;
for (int i = 5; i > 1; i--)
tnt += i;
cout << tnt;
cout << endl;
第 10 题 为实现如下效果,即 N 行 N 列字符。当输入是奇数时,中间列为 * , 其他是 -; 当输入是偶数时,则中间两列是 * , 其他是 -。字符阵列后的代码能实现其效果。( )
--*--
--*--
--*--
--*--
--*--
int N;
cin >> N;
int i,j;
for (i = 0; i < N; i++){
for (j = 0; j < N; j++)
if ((j == N / 2) || (j == (N-1) / 2))
cout << "*";
else
cout << "-";
cout << endl;
}
{{ select(25) }}
- 对
- 错