#CCF4281. [GESP202509二级] 客观题
[GESP202509二级] 客观题
一、单选题(每题 2 分,共 30 分)
第 1 题 人工智能现在非常火,小杨就想多了解一下,其中就经常听人提到"大模型"。那么请问这里说的"大模型"最贴切是指( )
{{ select(1) }}
- 大电脑模型
- 大规模智能
- 智能的单位
- 大语言模型
第 2 题 在 协议中,完成连接建立需要通过 ( ) 握手
{{ select(2) }}
- 一次
- 二次
- 三次
- 四次
第 3 题 下面的 代码用于输入姓名,然后输出姓名,正确的说法是 ( )
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 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(4) }}
N % div / 10
N / div / 10
N % div % 10
N / div % 10
第 5 题 下面 C++
代码执行,其输出是 ( )
01 a, b = 3, 4;
02 c = a == b;
03 cout << a << ' ' << b << ' ' << c;
{{ select(5) }}
3 4 0
3 3 3
4 4 4
- 以上都不对
第 6 题 某种编号的规则是 "XX-Y",其中 从 到 , 从 到 。第 个编号是 ,第 个编号是 ,第 个编号 ,第 个编号 ,即其编码规则是 和 同时增 ,到 到 时下一个变为 , 到 时,下一个变为 。下面的 C++
代码用于生成第 个编号,横线处应填上的代码是 ( )
01 cout << "请输入编号位置:";
02 cin >> N;
03
04 part1 = N % _____;
05 part2 = N % _____;
06
07 if (part1 < 10)
08 printf("0%d-%d\n", part1, part2);
09 else
10 printf("%d-%d\n", part1, part2);
{{ select(6) }}
12 10
10 10
11 9
9 9
第 7 题 下面的 C++
代码执行后其输出是 ( )
01 cnt = 0;
02 for (int i = -10; i < 10; i++)
03 for (int j =0; j < i; j++)
04 cnt += 1;
05 cout << cnt;
{{ select(7) }}
145
125
55
45
第 8 题 下面 C++
代码执行后其输出是 ( )
01 for (i =1; i < 12; i++){
02 if (i % 2 == 0)
03 continue;
04
05 for (j = 0; j < i; j++)
06 if (i * j % 2)
07 break;
08 }
09 if(i>= 12)
10 cout << (i * j);
{{ select(8) }}
110
12
- 不确定
- 无输出
第 9 题 阅读下面的 C++
代码,其中变量都是整型,则说法正确的是 ( )
01 cin >>a >> b;
02
03 while (b != 0){
04 remainder = a % b;
05 a = b;
06 b = remainder;
07 }
08 cout << a;
{{ select(9) }}
- 不能为 ,因为
a % b
将导致错误 - 必须小于 ,否则
a % b
将导致错误 - 和 都必须为正整数,否则
a % b
将导致错误 - 如果 输入为 ,则不管 的输入值是什么,输出值的绝对值都是
abs(b)
第 10 题 下面 C++
代码执行后输出是 ( )
01 num = 0;
02 while (num <= 5){
03 num += 1;
04 if (num == 3)
05 continue;
06 printf("%d#", num);
07 }
{{ select(10) }}
1#2#4#5#6#
1#2#4#5#6
1#2#3#4#5#6#
1#2#3#4#5#6
第 11 题 下面 C++
代码用于记录多个输入数中的最大数和最小数 (输入 则输入结束),相关说法错误的是 ( )
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
11 cin >> now_num;
12 }
13 cout << min_num << ' ' << max_num;
{{ select(11) }}
- 程序运行时如果第一个数输入 ,则输出将是
-999 -999
- 程序输入过程中,如果输入的第一个数不是 ,则如果待输入的数据中没有 ,则程序能求出已输入整数中的最大数和最小数
- 如果用于输入考试成绩,即成绩中不可能有 ,则程序能求出已输入成绩中的最高成绩和最低成绩
- 可以将
cin >> now_num;
移动到while (now_num != -999) {
下面,结果不变
第 12 题 下面 C++
代码执行后输出与 有关数的数量。"与 有关的数"定义为含有 或者能被 整除的数。相关说法正确的是 ( )
01 cnt = 0;
02 for (i = 1; i < 1000; i++){
03 if (i % 5 == 0){
04 cnt += 1;
05 continue;
06 }
07 j = i;
08 while (j > 0)
09 if (j % 10 == 5){
10 cnt += 1;
11 break;
12 }
13 else
14 j /= 10;
15 }
16 cout << cnt;
{{ select(12) }}
- 删除代码中
continue
不影响程序执行结果 - 删除
j = i
并将while
循环内的j
修改为i
,不影响程序执行结果 - 代码中
break
修改为j = 0
,不影响程序执行结果 - 将
while (j > 0)
修正为while (j >= 0)
不影响程序执行的结果
第 13 题 下面 C++
代码实现输出如下图形,应该在横线处填入的代码是 ( )
请输入层数:10
1
23
456
7891
23456
789123
4567891
23456789
123456789
1234567891
01 cout << "请输入层数:";
02 cin >> N;
03
04 K = 1;
05
06 for (i = 1; i < N + 1; i++){
07 for (int _ = 1; _ < ___________; _++)
08 cout << " ";
09
10 for (int _ = 1; _ < ________; _++){
11 cout << K;
12
13 K += 1;
14 if (K == 10)
15 K = 1;
16 }
17 cout << I\nI;
18 }
{{ select(13) }}
-
01 N - i + 1 02 i + 1
-
01 N - i 02 i
-
01 N 02 i
-
01 N - i 02 i + 1
第 14 题 下面 C++
代码执行,其输出是 ( )
01 int a=9, b=27;
02 a = IaI + IbI;
03 b = IaI – IbI;
04 a = a – b;
05 cout << a << I I << b << endl;
{{ select(14) }}
196 -1
27 9
98 97
- 不确定
第 15 题 有个无限长的链,由 种外形相同但材质不同的环链成。 种环的重量分别是 克,相同材质的多个环每 克一组,分别记为 。链依次 。同时对链上所有环从头依次编号 。输入正整数代表环编号,求该编号前所有环 (不含该环本身) 的重量。下面是 C++
代码是实现,正确说法是( )
01 i int N, G, R;
02 int wc = 0;
03
04 cin >> N; // 输入正整数
05 G = (N - 1) / 9; // L1
06 R = (N - 1) % 9; // L2: 保存余数
07 wc += 36*G;
08
09 if((1 <= R) && (R <= 4))
10 wc += 3*R; // L3
11 else if ((5 <= R) && (R <= 7))
12 wc += 4*R; // L4
13 else if(R == 8)
14 wc += 6*(R - 1); // L5
15 cout << wc << endl;
{{ select(15) }}
- 必须同时修改
L1
和L2
代码行才能实现功能 - 必须同时修改
L3
和L4
代码行才能实现功能 - 必须同时修改
L3
和L5
代码行才能实现功能 - 其他说法都不对
二、判断题(每题 2 分,共 20 分)
第 1 题 在集成开发环境里调试程序时,要注意不能修改源程序,因为如果修改,就要终止调试、关闭该文件并重新打开,才能再次开始调试。
{{ select(16) }}
- 正确
- 错误
第 2 题 在 C++
代码中,假设 为正整数且大于 ,则 N / 100
将舍弃个位和十位,如 为 1234
则 cout << (N / 100)
将输出 。如果 小于 ,则其值为 。
{{ select(17) }}
- 正确
- 错误
第 3 题 下列 C++
代码执行后将输出 ,因为 确实小于 和 。
01 a = 5;
02 cout << (a < 10 and 20);
{{ select(18) }}
- 正确
- 错误
第 4 题 下面的 C++
代码中变量都是整型,则执行后将输出 。
01 x, y, z = 5, 10, 15;
02 result = x < y < z;
03 cout << result;
{{ select(19) }}
- 正确
- 错误
第 5 题 下面 C++
代码执行时如输入 ,将输出及格两个汉字。
01 int score;
02 cout << "请输入学生成绩:";
03 cin >> score;
04 if (score >= 60)
05 printf("及格");
06 else
07 printf("不及格");
{{ select(20) }}
- 正确
- 错误
第 6 题 执行下面的 C++
代码时输入 ,则输出是 DCB
。
01 int a;
02 cin >> a;
03 while(a){
04 cout << 'A'+a%10;
05 a /= 10;
06 }
{{ select(21) }}
- 正确
- 错误
第 7 题 下面的 C++
代码执行后将输出 +#+#3#
。
01 int i;
02 for (i = Θ; i < 3; i++){
03 if (i == 2)
04 continue;
05 printf("+#");
06 }
07 cout << i << I#I;
{{ select(22) }}
- 正确
- 错误
第 8 题 下列 C++
代码用于求斐波那契数列,即第 个数 ,第 个数 ,从第三个数开始,是前两个数之和。如果输入的值为大于 的正整数,该代码能实现。
01 cin >> n;
02 a = Θ, b = 1;
03 for (int j = Θ; j < n; j++){
04 cout << a << " ";
05 b = b + a;
06 a = b - a;
07 }
{{ select(23) }}
- 正确
- 错误
第 9 题 下面的 C++
不能实现如下输出,但如果将 L1
标记的 cout << 0
行移动 if
块外面,或者说移动到 L2
标记行,则可以。
请输入矩阵大小n: 9
1ΘΘΘΘΘΘΘΘ
Θ2ΘΘΘΘΘΘΘ
ΘΘ3ΘΘΘΘΘΘ
ΘΘΘ4ΘΘΘΘΘ
ΘΘΘΘ5ΘΘΘΘ
ΘΘΘΘΘ6ΘΘΘ
ΘΘΘΘΘΘ7ΘΘ
ΘΘΘΘΘΘΘ8Θ
ΘΘΘΘΘΘΘΘ9
01 int n, i, j;
02 cout << "请输入矩阵大小n: ";
03 cin >> n;
04
05 for (i = Θ; i < n; i++){
06 for (j = Θ; j < n; j++){
07 if (i == j){
08 cout << i + 1;
09 continue;
10 cout << Θ; // L1
11 }
12 // L2
13 }
14 printf("\n");
15 }
{{ select(24) }}
- 正确
- 错误
第 10 题 C++
代码 cout << ('5'+4);
执行后的输出为 。
{{ select(25) }}
- 正确
- 错误