#GESPK202603C3. 三级理论

三级理论

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

  1. 如果字符变量 _1 的值是字符 '1' ,那么(int)_1 的值是( )。

{{ select(1) }}

  • 1
  • -1
  • 49
  • +1 或者 -1

  1. a,b 是整型变量,各自有互不相同的初始值。下列程序实现了什么效果( )。
a = a ^ b;
b = a ^ b;
a = a ^ b;

{{ select(2) }}

  • a,b 的值从始至终都没有改变
  • a,b 的值实现了互换
  • a,b 的值互换后又换回去
  • a,b 的值最后没有任何意义

  1. 关于下列正确的程序段,说法正确的是( )。
char str1[] = "Hello";
char str2[] = {'H','e','l','l','0'};

{{ select(3) }}

  • 字符数组 str1 和 str2 完全相同
  •  cout<<str1<<endl;
     cout<<str2<<endl; 
    
    这段程序将输出不同的结果
  • 字符数组 str1 和 str2 不相等
  • 两个赋值方式完全相同

  1. 关于以下程序段,说法正确的是( )。
int x=10;
cout<<(x++) + (++x)<<endl;

{{ select(4) }}

  • C++11 标准中这是未定义行为
  • 22
  • 21
  • 20

  1. 8 位二进制下,十进制数 -15 的补码是( )。

{{ select(5) }}

  • 11110000
  • 10001111
  • 10010000
  • 11110001

  1. 三进制数2102(3)2102_{(3)}转换成十进制是( )。

{{ select(6) }}

  • 63
  • 65
  • 67
  • 69

  1. 二进制数 10110101 是某数的 8 位补码,该数的十进制是( )。

{{ select(7) }}

  • -73
  • -75
  • -77
  • 75

  1. 已知 unsigned char c = 0x0F; (十六进制 0F = 二进制 00001111 ),执行 c = c << 3; 后, c 的十进制值是:( )。

{{ select(8) }}

  • 64
  • 72
  • 80
  • 120

  1. 补码情况下,关于按位取反运算说法错误的是( )。

{{ select(9) }}

  • ~5 的结果是 -6
  • ~0 的结果是 0
  • ~(-3) 的结果是 2
  • ~8 的结果是 -9

  1. 执行以下代码后,sub 的值是( )。
string str = "GESP2026";
string sub = str.substr(4,2);

{{ select(10) }}

  • 20
  • 02
  • 2026
  • 026

11.执行以下代码后输出是( )。

int arr[] = {5,10,15,20,25,30};
int count = sizeof(arr) / sizeof(arr[0]);
cout << count;

{{ select(11) }}

  • 4
  • 6
  • 24
  • 30

  1. 执行以下代码后输出结果是( )。
char s[10] = "abcde";
int a = sizeof(s) / sizeof(s[0]);
int b = strlen(s);
cout << a - b;

{{ select(12) }}

  • 4
  • 5
  • 6
  • 10

  1. 以下问题中,最不适合用 枚举法 解决的是( )。

{{ select(13) }}

  • 找出 1~100 之间所有能被 7 整除的数
  • 找出 100~200 之间所有质数
  • 计算 1+2+3+…+1000 的和
  • 找出三位数中各位数字之和等于10的数

  1. 用枚举法解决 鸡兔同笼问题(头35脚94),最合理的是( )。

{{ select(14) }}

  • 枚举鸡的数量 x (0~35),兔的数量 y=35-x ,判断 2*x + 4*y == 94
  • 枚举兔的数量 y (0~94),鸡的数量 x=35-y ,判断 2*x + 4*y == 94
  • 枚举所有整数 x (0-100)和 y (0-100),判断 x+y==35 && 2*x+4*y==94
  • 枚举脚的总数 sum (0~94),判断 sum == 94

  1. 模拟 “字符串加密”:规则为 “每个字符 ASCII 码+3,若超过 z (122) 则从 a 重新开始”,以下代码中正确的条件判断是:( )
for (int i = 0; i < str.length(); i++) {
    // 需补充条件:
    _______________________
    else {
        str[i] += 3;
    }
}

{{ select(15) }}

  • if (str[i] > 122) str[i] = str[i] + 3 - 26;
  • if (str[i] > 122) str[i] = str[i] - 26;
  • if (str[i] + 3 > 122) str[i] = str[i] - 23;
  • if (str[i] + 3 > 'z') str[i] = 'a' + (str[i] + 3 - 'z') - 1;

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

  1. 定义 int arr[5]={1,2,3};arr[3] 的值为 0,arr[5] 是合法下标。

{{ select(16) }}

  • 正确
  • 错误

  1. 定义
double arr[10];

未初始化时数组所有元素默认值为 0.0。

{{ select(17) }}

  • 正确
  • 错误

  1. 定义
int arr[]={1,2,3};

sizeof(arr) 的结果是 12。

{{ select(18) }}

  • 正确
  • 错误

19 下面的流程图是用来求 1+2+3+…+10的和。 请判断:这个流程图的逻辑正确还是错误?

{{ select(19) }}

  • 正确
  • 错误

  1. 下面流程图的功能是计算 5 对 2 取余数,输出结果为 1。

{{ select(20) }}

  • 正确
  • 错误

  1. 已知大写字符 A 的ASCII编码的十六进制表示为 0x41 ,计算字符 m 的ASCII编码的八进制表示为 155(八进制)。

{{ select(21) }}

  • 正确
  • 错误

  1. C++ 位运算符存在优先级,使用括号可以解决优先级问题。

{{ select(22) }}

  • 正确
  • 错误

  1. 0~255 范围内 charint 可以互换,因此 x 与 y 相等。
char x='1';
int y=1;

{{ select(23) }}

  • 正确

  • 错误


  1. 表达式
((0xf0 + 0x15) == 255)

结果为 true。

{{ select(24) }}

  • 正确
  • 错误

  1. 如果 aint 类型的变量,且 a 的二进制最低位为 0 ,则表达式 ((a & 3 & 1) == 0) 的值为true

{{ select(25) }}

  • 正确
  • 错误