#GESPK202603C3. 三级理论
三级理论
一、 单选题(每题 2 分,共 30 分)
- 如果字符变量
_1的值是字符 '1' ,那么(int)_1的值是( )。
{{ select(1) }}
- 1
- -1
- 49
- +1 或者 -1
- a,b 是整型变量,各自有互不相同的初始值。下列程序实现了什么效果( )。
a = a ^ b;
b = a ^ b;
a = a ^ b;
{{ select(2) }}
- a,b 的值从始至终都没有改变
- a,b 的值实现了互换
- a,b 的值互换后又换回去
- a,b 的值最后没有任何意义
- 关于下列正确的程序段,说法正确的是( )。
char str1[] = "Hello";
char str2[] = {'H','e','l','l','0'};
{{ select(3) }}
- 字符数组 str1 和 str2 完全相同
-
这段程序将输出不同的结果cout<<str1<<endl; cout<<str2<<endl; - 字符数组 str1 和 str2 不相等
- 两个赋值方式完全相同
- 关于以下程序段,说法正确的是( )。
int x=10;
cout<<(x++) + (++x)<<endl;
{{ select(4) }}
- C++11 标准中这是未定义行为
- 22
- 21
- 20
- 8 位二进制下,十进制数 -15 的补码是( )。
{{ select(5) }}
- 11110000
- 10001111
- 10010000
- 11110001
- 三进制数转换成十进制是( )。
{{ select(6) }}
- 63
- 65
- 67
- 69
- 二进制数
10110101是某数的 8 位补码,该数的十进制是( )。
{{ select(7) }}
- -73
- -75
- -77
- 75
- 已知 unsigned char c = 0x0F; (十六进制 0F = 二进制 00001111 ),执行 c = c << 3; 后, c 的十进制值是:( )。
{{ select(8) }}
- 64
- 72
- 80
- 120
- 补码情况下,关于按位取反运算说法错误的是( )。
{{ select(9) }}
- ~5 的结果是 -6
- ~0 的结果是 0
- ~(-3) 的结果是 2
- ~8 的结果是 -9
- 执行以下代码后,
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
- 执行以下代码后输出结果是( )。
char s[10] = "abcde";
int a = sizeof(s) / sizeof(s[0]);
int b = strlen(s);
cout << a - b;
{{ select(12) }}
- 4
- 5
- 6
- 10
- 以下问题中,最不适合用 枚举法 解决的是( )。
{{ select(13) }}
- 找出 1~100 之间所有能被 7 整除的数
- 找出 100~200 之间所有质数
- 计算 1+2+3+…+1000 的和
- 找出三位数中各位数字之和等于10的数
- 用枚举法解决 鸡兔同笼问题(头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
- 模拟 “字符串加密”:规则为 “每个字符 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 分)
- 定义
int arr[5]={1,2,3};则arr[3]的值为 0,arr[5]是合法下标。
{{ select(16) }}
- 正确
- 错误
- 定义
double arr[10];
未初始化时数组所有元素默认值为 0.0。
{{ select(17) }}
- 正确
- 错误
- 定义
int arr[]={1,2,3};
sizeof(arr) 的结果是 12。
{{ select(18) }}
- 正确
- 错误
19
下面的流程图是用来求 1+2+3+…+10的和。
请判断:这个流程图的逻辑正确还是错误?

{{ select(19) }}
- 正确
- 错误
- 下面流程图的功能是计算 5 对 2 取余数,输出结果为 1。

{{ select(20) }}
- 正确
- 错误
- 已知大写字符 A 的ASCII编码的十六进制表示为 0x41 ,计算字符 m 的ASCII编码的八进制表示为 155(八进制)。
{{ select(21) }}
- 正确
- 错误
- C++ 位运算符存在优先级,使用括号可以解决优先级问题。
{{ select(22) }}
- 正确
- 错误
- 在
0~255范围内char与int可以互换,因此 x 与 y 相等。
char x='1';
int y=1;
{{ select(23) }}
-
正确
-
错误
- 表达式
((0xf0 + 0x15) == 255)
结果为 true。
{{ select(24) }}
- 正确
- 错误
- 如果
a为int类型的变量,且a的二进制最低位为0,则表达式 ((a & 3 & 1) == 0) 的值为true。
{{ select(25) }}
- 正确
- 错误