#CCF4281. [GESP202509二级] 客观题

[GESP202509二级] 客观题

一、单选题(每题 2 分,共 30 分)

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

{{ select(1) }}

  • 大电脑模型
  • 大规模智能
  • 智能的单位
  • 大语言模型

第 2 题TCPTCP 协议中,完成连接建立需要通过 ( ) 握手

{{ select(2) }}

  • 一次
  • 二次
  • 三次
  • 四次

第 3 题 下面的 C++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++ 代码用于获得正整数 NN 的第 MM 位数,如 NN 等于 12341234MM 等于 22,则输出 33。此题假设 MM 的值大于等于 11 且小于等于 NN 的位数。横线处应填入的代码是 ( )

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",其中 XXXX00001111YY0099。第 11 个编号是 00000-0,第 22 个编号是 01101-1,\cdots,第 1212 个编号 11111-1,第 1313 个编号 00200-2,即其编码规则是 XXXXYY 同时增 11,到 XXXX1111 时下一个变为 0000YY99 时,下一个变为 00。下面的 C++ 代码用于生成第 NN 个编号,横线处应填上的代码是 ( )

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) }}

  • bb 不能为 00,因为 a % b 将导致错误
  • aa 必须小于 bb,否则 a % b 将导致错误
  • aabb 都必须为正整数,否则 a % b 将导致错误
  • 如果 aa 输入为 00,则不管 bb 的输入值是什么,输出值的绝对值都是 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++ 代码用于记录多个输入数中的最大数和最小数 (输入 999-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
11     cin >> now_num;
12 }
13 cout << min_num << ' ' << max_num;

{{ select(11) }}

  • 程序运行时如果第一个数输入 999-999,则输出将是 -999 -999
  • 程序输入过程中,如果输入的第一个数不是 999-999,则如果待输入的数据中没有 999-999,则程序能求出已输入整数中的最大数和最小数
  • 如果用于输入考试成绩,即成绩中不可能有 999-999,则程序能求出已输入成绩中的最高成绩和最低成绩
  • 可以将 cin >> now_num; 移动到 while (now_num != -999) { 下面,结果不变

第 12 题 下面 C++ 代码执行后输出与 55 有关数的数量。"与 55 有关的数"定义为含有 55 或者能被 55 整除的数。相关说法正确的是 ( )

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 题 有个无限长的链,由 33 种外形相同但材质不同的环链成。33 种环的重量分别是 3463、4、6 克,相同材质的多个环每 1212 克一组,分别记为 G3G4G6G3、G4、G6。链依次 G3G4G6G3G4G6G3、G4、G6、G3、G4、G6、\cdots。同时对链上所有环从头依次编号 12341、2、3、4 \cdots。输入正整数代表环编号,求该编号前所有环 (不含该环本身) 的重量。下面是 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) }}

  • 必须同时修改 L1L2 代码行才能实现功能
  • 必须同时修改 L3L4 代码行才能实现功能
  • 必须同时修改 L3L5 代码行才能实现功能
  • 其他说法都不对

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

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

{{ select(16) }}

  • 正确
  • 错误

第 2 题C++ 代码中,假设 NN 为正整数且大于 100100,则 N / 100 将舍弃个位和十位,如 NN1234cout << (N / 100) 将输出 1212。如果 NN 小于 100100,则其值为 00

{{ select(17) }}

  • 正确
  • 错误

第 3 题 下列 C++ 代码执行后将输出 11,因为 aa 确实小于 20201010

01 a = 5;
02 cout << (a < 10 and 20);

{{ select(18) }}

  • 正确
  • 错误

第 4 题 下面的 C++ 代码中变量都是整型,则执行后将输出 11

01 x, y, z = 5, 10, 15;
02 result = x < y < z;
03 cout << result;

{{ select(19) }}

  • 正确
  • 错误

第 5 题 下面 C++ 代码执行时如输入 99.9999.99,将输出及格两个汉字。

01 int score;
02 cout << "请输入学生成绩:";
03 cin >> score;
04 if (score >= 60)
05     printf("及格");
06 else
07     printf("不及格");

{{ select(20) }}

  • 正确
  • 错误

第 6 题 执行下面的 C++ 代码时输入 123123,则输出是 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++ 代码用于求斐波那契数列,即第 11 个数 00,第 22 个数 11,从第三个数开始,是前两个数之和。如果输入的值为大于 11 的正整数,该代码能实现。

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); 执行后的输出为 99

{{ select(25) }}

  • 正确
  • 错误