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