#GESP202603C3T1. 单选题(每题 2 分,共 30 分)
单选题(每题 2 分,共 30 分)
一、单选题(每题 2 分,共 30 分)
第 1 题 如果字符变量 _1 的值是字符 1,那么 (int)_1 的值是( )。
{{ select(1) }}
- 1
- -1
- 49
- +1 或者 -1
第 2 题 a, b 是整型变量,各自有互不相同的初始值。下列程序实现了什么效果( )。
1 a = a ^ b;
2 b = a ^ b;
3 a = a ^ b;
{{ select(2) }}
- a, b 的值从始至终都没有改变。
- a, b 的值实现了互换。
- a, b 的值互换了以后,又还回去了,相当于没有变化。
- a, b 的值最后和原值不一样,没有任何意义。
第 3 题 关于下列正确的程序段,说法正确的是( )。
1 char str1[] = "Hello";
2 char str2[] = {'H','e','l','l','o'};
{{ select(3) }}
- 字符数组 str1 和 str2 完全相同。
-
这段程序多次执行将输出不同的结果。cout << str1 << endl; cout << str2 << endl; - 字符数组 str1 和 str2 不相等。
- 这两个赋值方式完全相同。
第 4 题 关于以下程序段,说法正确的是( )。
1 int x = 10;
2 cout << (x++) + (++x) << endl;
{{ select(4) }}
- C++11 标准中,这是未定义行为,不同的环境有可能出现不同的结果。
- 22
- 21
- 20
第 5 题 8 位二进制下,十进制数 -15 的补码是( )。
{{ select(5) }}
- 11110000
- 10001111
- 10010000
- 11110001
第 6 题 三进制数 210₂₍₃₎ 转换成十进制是( )。
{{ select(6) }}
- 63
- 65
- 67
- 69
第 7 题 二进制数 10110101 是某数的 8 位补码,该数的十进制是( )。
{{ select(7) }}
- -73
- -75
- -77
- 75
第 8 题 已知 unsigned char c = 0x0F;(十六进制 0F = 二进制 00001111),执行 c = c << 3; 后,c 的十进制值是( )。
{{ select(8) }}
- 64
- 72
- 80
- 120
第 9 题 补码的情况下,关于按位取反运算,用笔计算的情况下,以下说法错误的是( )。
{{ select(9) }}
~5的结果是 -6(int 类型,32 位)~0的结果是 0(int 类型,32 位)~(-3)的结果是 2(int 类型,32 位)~8的结果是 -9(int 类型,32 位)
第 10 题 执行以下 C++ 代码后,sub 的值是( )。
string str = "GESP2026";
string sub = str.substr(4, 2);
{{ select(10) }}
- "20"
- "P2"
- "S2"
- "ES"
第 11 题 执行以下代码后,输出结果是:( )。
int arr[] = {5, 10, 15, 20, 25, 30};
int count = sizeof(arr) / sizeof(arr[0]);
cout << count;
{{ select(11) }}
- 4
- 6
- 24
- 30
第 12 题 执行以下代码后,输出结果是:( )。
char s[10] = "abcde";
int a = sizeof(s) / sizeof(s[0]);
int b = strlen(s);
cout << a - b;
{{ select(12) }}
- 4
- 5
- 6
- 10
第 13 题 以下问题中,最不适合用枚举法解决的是:( )
{{ select(13) }}
- 找出 1~100 之间所有能被 7 整除的数
- 找出 100~200 之间的所有质数
- 计算 1+2+3+…+1000 的和
- 找出三位数中个位、十位、百位数字之和等于 10 的数
第 14 题 用枚举法解决 “鸡兔同笼问题:头共 35 个,脚共 94 只,求鸡和兔的数量”,以下枚举逻辑最合理的是:( )
{{ select(14) }}
- 枚举鸡的数量 x (0~35),兔的数量 y=35-x ,判断 2x + 4y == 94
- 枚举兔的数量 y (0~94),鸡的数量 x=35-y ,判断 2x + 4y == 94
- 枚举所有整数 x (0-100)和 y (0-100),判断 x+y35 && 2x+4y94
- 枚举脚的总数 sum (0~94),判断 sum == 94
第 15 题 模拟 “字符串加密”:规则为 “每个字符 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] - 26;
- if (str[i] + 3 > 'z') str[i] = 'a' + (str[i] + 3 - 'z') - 1;