#CCF4181. [GESP202509一级] 客观题

[GESP202509一级] 客观题

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

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

{{ select(1) }}

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

第 2 题 小杨这学期刚开学就选修了一门编程课,然后就想编写程序来计算 111000110001 之间的所有偶数的和。他希望程序采用简单累加整数的方法,同时希望源程序尽可能清晰、简洁,则下面关于实现累加时采用的主要控制结构的哪个说法最不合适 ( )

{{ 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++ 代码中 aabb 都是整型变量,执行后,其结果是 ( )

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

  • 1010
  • 55
  • 22
  • 00

第 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 题 当前是 99 月,编写 C++ 代码求 NN 个月后的月份。横线处应填入的代码是 ( )

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++ 代码用于求 NN 的镜面数 (NN 的个位到最高位的各位数字依次反过来出现在数字中,但高位 00 将被忽略,不输出),如输入 12341234,则将输出 43214321,又如输入 120120,则将输出 2121,错误的选项是 ( )

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++ 代码用于交换两个正整数 ab 的值,不能实现交换的代码是 ( )

{{ 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++ 代码用于获得正整数 NN 的第 MM 位数,约定个位数为第 11 位,如 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(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 将报错,因为 0.50.5 所在位置只能是整数。

{{ select(17) }}

  • 正确
  • 错误

第 3 题 下面C++代码执行后将输出 9。

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

{{ select(18) }}

  • 正确
  • 错误

第 4 题 下面 C++ 代码执行后将输出 5555

01 n = 0;
02 for (int i = 0; i > -10; i--)
03     n = n + i * -1;
04 cout << n;

{{ select(19) }}

  • 正确
  • 错误

第 5 题 将下面 C++ 代码中的 L1L1 行的 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++ 代码执行后将输出 4545

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) 将报错,因为 1212int 类型,而 12.1212.12floa 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++ 代码用于求斐波那契数列,即第 11 个数为 00,第 22 个数为 11,从第三个数开始,依次是其前两个数之和。如果输入的值为大于 11 的正整数,该代码能实现所求。

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

  • 正确
  • 错误