#X000111. GESP C++一级试卷(2025年9月)
GESP C++一级试卷(2025年9月)
一、选择题
本试卷共15道单项选择题,考察基本语法、逻辑结构和简单算法。
第1题
人工智能现在非常火,小杨就想多了解一下,其中就经常听人提到“大模型”。那么请问这里说的“大模型”最贴切是指( )。
{{ select(1) }}
- 大电脑模型
- 大规模智能
- 智能的单位
- 大语言模型
第2题
小杨这学期刚开学就选修了一门编程课,然后就想编写程序来计算 1 到 1000 之间的所有偶数的和。他希望程序采用简单累加整数的方法,同时希望程序尽可能清晰、简洁,则下面关于实现累加时采用的主要控制结构的哪个说法最不合适( )。
{{ select(2) }}
- 使用循环结构
- 使用循环和分支的组合
- 仅使用顺序结构
- 不使用分支结构
第3题
下面的 C++ 代码用于输入姓名,然后输出姓名,正确的说法是( )。
1 string XingMing;
2 cout << "请输入您的姓名:";
3 cin >> XingMing;
4 cout << XingMing;
{{ select(3) }}
- XingMing 是汉语拼音,不能作为变量名称
- 可以将 XingMing 改为 Xing Ming
- 可以将 XingMing 改为 xingming
- 可以将 XingMing 改为 Xing-Ming
第4题
下列 C++ 代码中 a 和 b 都是整型变量,执行后,其结果是( )。
1 a = 13;
2 b = 5;
3 cout << a / b << a %// b << a % b;
4 a*b;
{{ select(4) }}
- 2 3
- 23
- 20
- 以上都不准确
第5题
C++表达式 3 * 4 % 5 / 6 的值是( )。
{{ select(5) }}
- 10
- 5
- 2
- 0
第6题
下面的C++代码中变量N和M都是整型,则执行时如果先输入10并输入一个制表符后输入20并回车,其输出的数值是( )。
1 scanf("%d", &N);
2 scanf("%d", &M);
3 printf("%d\n", N+N);
{{ select(6) }}
- 30
- 1020
- N+N
- 不输出,继续等待输入
第7题
当前是9月,编写C++代码求N个月后的月份。横线处应填入的代码是( )。
1 int N, M;
2 cin >> N;
3 M = ______;
4 if (M == 0)
5 printf("%d个月后是12月", N);
6 else
7 printf("%d个月后是%d月", N, M);
{{ select(7) }}
- N % 12
- 9 + N % 12
- (9 + N) / 12
- (9 + N) % 12
第8题
下面C++代码执行后的输出是( )。
1 int n = 0;
2 for (int i = 0; i < 100; i++)
3 n += i % 2;
4 cout << n;
{{ select(8) }}
- 5050
- 4950
- 50
- 49
第9题
下面的C++代码执行后输出是( )。
int N = 0, i;
for (i = -100; i < 100; i++)
N += i % 10;
cout << N;
{{ select(9) }}
- 900
- 100
- 0
- -100
第10题
下面C++代码执行后输出是( )。
int i;
for(i = 1; i < 5; i++) {
if(i % 3 == 0)
break;
printf("%d#",i);
}
if(i > 5) printf("END\n");
{{ select(10) }}
- 1#2#
- 1#2#END
- 1#2
- 1#2#3#4#END
第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;
{{ select(11) }}
- N != 0
- not (N == 0)
- N = 0
- N > 0
第12题
下面C++代码用于交换两个正整数a和b的值,不能实现交换的代码是( )。
{{ select(12) }}
-
cout << "输入第一个正整数:"; cin >> a; cout << "输入第二个正整数:"; cin >> b; temp = a; a = b; b = temp; cout << "a=" << a << " b=" << b << endl; -
cout << "输入第一个正整数: "; cin >> a; cout <<"输入第二个正整数: "; cin >> b; b = a - b; a = a - b; b = a + b; cout << "a=" << a << " b=" << b << endl; -
cout << "输入第一个正整数: "; cin >> a; cout <<"输入第二个正整数: "; cin >> b; a = a + b; b = a - b; a = a - b; cout << "a=" << a << " b=" << b << endl; -
cout << "输入第一个正整数: "; cin >> a; cout <<"输入第二个正整数: "; cin >> b; a, b = b, a; cout << "a=" << a << " b=" << b << endl;
第13题
下面C++代码用于获得正整数N的第M位数,约定个位数为第1位,如N等于1234,M等于2,则输出3。假设M的值是大于等于1且小于等于N的位数。横线处应填入的代码是( )。
1 int N, M, div=1;
2 cout << "请输入一个正整数: ";
3 cin >> N;
4 cout <<"请输入从右到左取第几位数: ";
5 cin >> M;
6
7 for (int i =0; i < (M - 1); i++) div *= 10;
8
9 cout << (______);
{{ select(13) }}
- N % div / 10
- N / div / 10
- N % div % 10
- N / div % 10
第14题
下面C++代码执行后输出是( )。
1 num = 0;
2 while (num <= 5){
3 num += 1;
4 if (num == 3)
5 continue;
6 printf("%d#", num);
7 }
{{ select(14) }}
- 1#2#4#5#6#
- 1#2#4#5#6
- 1#2#3#4#5#6#
- 1#2#3#4#5#6
第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;
{{ select(15) }}
- 程序运行时如果第一个数输入 -999 ,则输出将是-999 -999
- 程序输入过程中,如果输入的第一个数不是 -999 ,则如果待输入的数据中没有 -999 ,则程序能求出已输入整数中的最大数和最小数
- 如果用于输入考试成绩,即成绩中不可能有 -999 ,则程序能求出已输入成绩中的最高成绩和最低成绩
- 可以将cin >> now_num; 移动到while (now_num != -999) { 下面,结果不变
二、判断题
本试卷共10道判断题,考察基本概念和代码理解。
第16题
在集成开发环境里调试程序时,要注意不能修改源程序,因为如果修改,就要终止调试、关闭该文件并重新打开,才能再次开始调试。( )
{{ select(16) }}
- 正确
- 错误
第17题
执行C++表达式10 % 0.5 将报错,因为 0.5 所在位置只能是整数。( )
{{ select(17) }}
- 正确
- 错误
第18题
下面C++代码执行后将输出 9 。( )
for (i = 0; i < 10; i++)
break;
cout << i;
{{ select(18) }}
- 正确
- 错误
第19题
下面C++代码执行后将输出 55 。( )
n = 0;
for (int i = 0; i > -10; i--)
n = n + i * -1;
cout << n;
{{ select(19) }}
- 正确
- 错误
第20题
将下面C++代码中的 L1 行的i = 0 修改为i = 1 , 其输出与当前代码输出相同。( )
cnt = 0;
for (int i = 0; i < 100; i++) // L1
cnt += i;
cout << cnt
{{ select(20) }}
- 正确
- 错误
第21题
将下面C++代码中的i < 10修改为i <= 10,其执行后输出相同。( )
1 int n, i;
2 n = i = 0;
3 while (i < 10){
4 n += i;
5 i += 1;
6 }
7 cout << n;
{{ select(21) }}
- 正确
- 错误
第22题
下面的C++代码执行后将输出45。( )
1 int n, i;
2 n = i = 0;
3 while (i < 10){
4 i += 1;
5 n += i;
6 }
7 cout << n;
{{ select(22) }}
- 正确
- 错误
第23题
执行C++代码cout << (12 + 12.12)将报错,因为12是int类型,而12.12是float类型,不同类型不能直接运算。( )
{{ select(23) }}
- 正确
- 错误
第24题
下面C++代码执行时将导致无限循环(也称死循环)。( )
1 int count = 0;
2 while (count < 5){
3 count += 1;
4 if (count == 3)
5 continue;
6 cout << count << ' ';
7 }
{{ select(24) }}
- 正确
- 错误
第25题
下列C++代码用于求斐波那契数列,即第1个数为0,第2个数为1,从第三个数开始,依次是其前两个数之和。如果输入的值为大于1的正整数,该代码能实现所求。( )
1 cin >> n;
2 a = 0, b = 1;
3 for (int j = 0; j < n; j++){
4 cout << a << " ";
5 b = b + a;
6 a = b - a;
7 }
{{ select(25) }}
- 正确
- 错误