#GESP1309. [GESP202512二级] 客观题

[GESP202512二级] 客观题

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

第 1 题 近日,空中客车公司表示,约 60006000 架空客A320A320 系列飞机需要紧急更换一种易受太阳辐射影响的飞行控制软件。空客表示,在对一起飞行事故分析后的结果显示,强烈的太阳辐射可能会损坏飞行控制系统所需的关键数据,导致判断失误,进而引发飞行异常。那这里的飞行控制系统执行判断的部件最可能是下面的( )。

{{ select(1) }}

  • 辐射传感器
  • 处理器
  • 内存单元
  • 输出设备

第 2 题 小明最近为了备考 GESPGESP,开始看 BB 站上关于网络知识的视频。其中提到计算机网络系统有不同的划分标准,那他平时上学所在的教学楼内的网络是⼀个( )

{{ select(2) }}

  • PAN
  • LAN
  • MAN
  • WAN

第 3 题 下⾯有关 C++ 变量的说法,正确的是( )。

{{ select(3) }}

  • 不可以用 for 作为变量名,因为 forC++ 的关键字(保留字)。
  • _tnt 不可以是变量名,因为变量名的第一个字符必须是英文字母。
  • _tnt_ 不可以是变量名,因为最后一个字符容易与减号混淆。
  • 可以用 printf 作为变量名,因为 printf 是关键字,但这不是好习惯,因为 printf 有约定的功能与含义。

第 4 题 一个小数是 0.123123123…… 无限循环,其小数点后 11 位是 11,后 22 位是 22,依此类推,求第 NN 位的值。横线处应填入的代码是( )。

01 int N;
02 cin >> N;
03 remainder = ______________;
04 
05 if (remainder == 0)
06     cout << 1;
07 else if (remainder == 1)
08     cout << 2;
09 else
10     cout << 3;

{{ select(4) }}

  • N % 3
  • (N - 1) % 3
  • N / 3
  • (N - 1) / 3

第 5 题 某同学执行 C++ 代码时 printf("%g\n", (3+3.1415926535)); 输出 6.141596.14159,其原因最可能是 ( )

{{ select(5) }}

  • C++ 中整数和浮点数相加时,整数会被转换为浮点数,而某些十进制小数无法精确表示为二进制小数,从而产生某些舍入误差。
  • C++printf 函数在输出浮点数时根据格式有默认小数点位数,因此输出了较少的位数。
  • 3.14159265353.1415926535 是一个无限循环小数,在计算机中无法精确表示。
  • 由于计算机 CPUCPU 的运算错误导致。

第 6 题 某单位工号的编码规则:编码总长 55 位,均为数字,前 44 位依次整除以 33 其值累加之和除以 1010 的余数为第 55 位数字。如某工号为 7658776587,前 44 位分别整除以 33 后,商分别为 2、2、1、2,其累加之和为 77,除以 1010 的余数为 77,故第 55 位为 77。下面代码依次输入前 44 位后,两个横线处分别应填的是 ( )

01 int rst = 0, N;
02 for (int i = 0; i < 4; i++){
03     cin >> N;
04     rst += ___________; // L1
05 }
06 cout << ___________; // L2

{{ select(6) }}

  • 01 N % 3
    02 rst / 10
    
  • 01 N % 3
    02 rst % 10
    
  • 01 N / 3
    02 rst / 10
    
  • 01 N / 3
    02 rst % 10
    

第 7 题 下面的 C++ 代码执行后的输出是( )。

01 for (int i = -2; i < 2; i++)
02     if (i % 2)
03         printf("%d#",i);

{{ select(7) }}

  • -1#1#
  • -1#0#1#
  • -2#-1#1#
  • -2#-1#1#2#

第 8 题 下面的 C++ 代码执行后其输出是( )。

01 int cnt = 0, N;
02 for (int i =1; i < 10; i += 2)
03     for (int j =0; j < i; j++)
04         cnt += 1;
05 cout << cnt;

{{ select(8) }}

  • 100100
  • 5555
  • 4545
  • 2525

第 9 题 下面的 C++ 代码执行后其输出是( )。

01 int i,j;
02 
03 for (i = 1; i < 12; i++){
04     if (i % 2 == 0)
05         continue;
06
07     for (j = 0; j < i; j++)
08         if (i * j % 2 == 0)
09             break;
10     if(j >= i)
11         cout << i * j << " ";
12 }
13 if(i >= 12)
14     cout << (i * j);

{{ select(9) }}

  • 0 0
  • 11
  • 0
  • 0 11

第 10 题 与下面 C++ 输出效果不一致的代码是( )

01 int i;
02 for (i = 0; i < 10; i++)
03     cout << i;

{{ select(10) }}

  • 01 int i = 0;
    02 while (i < 10){
    03     cout << i;
    04     i += 1;
    05 }
    
  • 01 int i = 0;
    02 while (i < 10){
    03 i += 1;
    04 cout << i;
    05 }
    
  • 01 int i = 0;
    02 while (true){
    03     cout << i;
    04     i += 1;
    05     if (i >= 10)
    06         break;
    07 }
    
  • 01 int i = 0;
    02 while (true){
    03     if (i >= 10)
    04         break;
    05     cout << i;
    06     i += 1;
    07 }
    

第 11 题 下面 C++ 代码执行后输出是( )。

01 int num = 0;
02 while (num <= 5){
03     num += 1;
04     if (num % 3)
05         continue;
06     printf("%d#",num);
07 }
08 if(num > 5)
09     printf("%d", num);

{{ select(11) }}

  • 3#6#
  • 3#6#6
  • 1#2#3#4#5#6#
  • 1#2#3#4#5#6#6

第 12 题 下面 C++ 代码执行后,其输出是( )

01 int cnt = 0;
02 for (int i = 0; i <5; i++)
03     for (int j =i; j < 4; j++)
04         cnt += 1;
05 cout << cnt;

{{ select(12) }}

  • 99
  • 1010
  • 1414
  • 2020

第 13 题 漂亮数的定义是:如果 NN 能被 MM 整除,或者某位是 MM,或者 NN 的每位数之和能被 MM 整除,则说 NNMM 的漂亮数。如果三个条件都满足,则是完整漂亮数。12312333 的完整漂亮数,因为 123123 能被 33 整除,也含有 33,其每位数之和为 66 也能被 33 整除。下面的代码用于判断 NN 是否为 MM 的完整漂亮数并输出。相关说法正确的是( )。

01 int N, M, Flag, Sum, num;
02 cout << "请输入N,不等于0的正整数:";
03 cin >> N;
04 cout << "请输入M:M必须大于1小于9:";
05 cin >> M;
06
07 Sum = 0; // 记录各位数之和
08 Flag = 0; // 假设记录N不含有M
09 
10 while (N != 0){
11     num = N % 10;
12
13     Sum += num;
14     if (num == M)
15         Flag = 1;
16
17         N /= 10;
18 }
19 if ((N % M == 0) && (Flag == 1) && (Sum % M == 0)) // L1
20     printf("%d 是 %d 的完整漂亮数", N, M);
21 else
22     printf("%d 不是 %d 的完整漂亮数", N, M);

{{ select(13) }}

  • 代码能完成题目设定目标。
  • while 循环中 NN 最终将变成 00,因此 L1 行代码中 N%M 将总是满足条件,可以在 while 前增加一行代码 int old_num= N;,并将 L1 开始这 44 行代码中的 NN 都改为 old_num 就可以做出正确的判定。
  • while 循环中 if 判断语句可以增加 else 子句,其内容为 Flag=0
  • 如果先后输入 0033,则肯定会输出 0033 的完整漂亮数。

第 14 题 阅读下面的 C++ 代码。执行后如输入 55,其输出的字符图形是 ( )。

01 int n,i,j,k;
02 cin >> n;
03 for (i = 0; i < n; i++){
04     for (j = 0; j < n-i-1; j++)
05         cout << " ";
06     for (k = 0; k < 2*i+1; k++)
07         cout << "*";
08     cout << endl;
09 }

{{ select(14) }}

  • 01*****
    02****
    03***
    04**
    05*
    
  • 01    *
    02   ***
    03  *****
    04 *******
    05*********
    
  • 01*
    02**
    03***
    04****
    05*****
    
  • 01    *
    02   **
    03  ***
    04 ****
    05*****
    

第 15 题 某学校举办“十佳歌手大奖赛”,经过选拔最终参赛选手有 2525 人,评委 1010 人,最终计分规则去掉一个最高分去掉一个最低分作为该参赛选手的最终得分,并输出该得分。如果单个评委可给满分为 1010 分,则相关说法正确的是 ( )

01 float total_score, max_score, min_score, now_score;
02 for (int i = 0; i < 25; i++){
03     max_score = 0;  // 记录最高分
04     min_score = 10; // 记录最低分
05     total_score = 0; // 记录总分
06
07     for (int j = 0; j < 10; j++){
08         cin >> now_score; // 录入评委打分
09
10         max_score = max(max_score, now_score); // L1
11         min_score = min(min_score, now_score); // L2
12
13         total_score += now_score;
14     }
15
16     cout << (total_score - max_score - min_score);
17 }

{{ select(15) }}

  • 程序总体逻辑错误。因为要去掉最高分和最低分,需要排序,而程序没有相关代码。
  • 内层循环和外层循环之间的三行代码也就是 max_score=0开始的三行代码应该移动到外层循环外。
  • L1L2 标记的两行代码可以分别改为简单的 if 语句或 ?: 语句。
  • total_score += now_score 不以更为 total_score = total_score + now_score

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

第 1 题 鸿蒙是华为公司开发的一款操作系统,那么它能够将正确的源程序翻译成目标程序,并运行。

{{ select(16) }}

  • 正确
  • 错误

第 2 题 C++ 表达式 5<10 && 20 对应的逻辑值为 truetrue

{{ select(17) }}

  • 正确
  • 错误

第 3 题 C++ 表达式 10 / 0.333333 == 10 /(1/ 3) 的值为 truetrue

{{ select(18) }}

  • 正确
  • 错误

第 4 题 下面 C++ 代码中 NN 是整数,执行时无论输入负整数、00 或正整数,其输出都将是 00

01 in >> N;
02 while (N)
03     N /= 10;
04 cout << N;

{{ select(19) }}

  • 正确
  • 错误

第 5 题 下面的 C++ 代码执行后,其输出是 4 0

01 int a,b;
02 a = 4;
03 b = a == 5;
04 cout << a << ' ' << b;

{{ select(20) }}

  • 正确
  • 错误

第 6 题 C++ 代码中对表达式 ('Z'-'A')<('z'-'A') 的结果输出为 θθ

{{ select(21) }}

  • 正确
  • 错误

第 7 题 下面的 C++ 代码可以用于判断正整数 NN 的位数(即几位数,如 12312333 位数,121222 位数)。

01 int N, N10, i;
02 cin >> N;
03 N10 = 10, i = 1;
04 while (1) {
05     if (N % N10 == N) {
06         printf("%d 是 %d 位数", N, i);
07         break;
08     }
09     i++, N10 *= 10;
10 }

{{ select(22) }}

  • 正确
  • 错误

第 8 题 计算交叉加减的结果,形如 1-2+3-4+5-...。下面 C++ 代码中的变量都是整型,则将 FLag=-Flag 改为 Flag-=Flag 效果相同。

01 cin >> N;
02 Flag = -1;
03 tnt = 0;
04 for (i = 1; i < N + 1; i++) {
05     Flag = -Flag;
06     tnt += Flag * i;
07 }
08 cout << tnt;

{{ select(23) }}

  • 正确
  • 错误

第 9 题 下列 C++ 代码段执行后将输出 5555

01 int cnt = 0;
02 for (i = 0; i < 10; i++)
03     for (j = i; j < 10; j++)
04         cnt += 1;
05 cout << cnt;

{{ select(24) }}

  • 正确
  • 错误

第 10 题 下面 C++ 代码执行后输出如下,因为代码printf("\n") 没有任何可读内容,删除不影响输出效果。

1  2  3  4  5  6  7  8  9
2  4  6  8 10 12 14 16 18
3  6  9 12 15 18 21 24 27
4  8 12 16 20 24 28 32 36
5 10 15 20 25 30 35 40 45
6 12 18 24 30 36 42 48 54
7 14 21 28 35 42 49 56 63
8 16 24 32 40 48 56 64 72
9 18 27 36 45 54 63 72 81
01 for (int i = 1; i < 10; i++) {
02     for(int j = 1; j < 10; j++)
03         printf("%3d", i * j);
04     printf("\n");
05 }

{{ select(25) }}

  • 正确
  • 错误