#GESP202603C3T1. 选择题

选择题

第 1 题

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

{{ select(1) }}

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

第 2 题

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

a = a ^ b;
b = a ^ b;
a = a ^ b;

{{ select(2) }}

  • a, b的值从始至终都没有改变。
  • a, b的值实现了互换。
  • a, b的值互换了以后,又还回去了,相当于没有变化。
  • a, b的值最后和原值不一样,没有任何意义。

第 3 题

关于下列正确的程序段,说法正确的是()

char str1[] = "Hello";
char str2[] = {'H', 'e', 'l', 'l', 'o'};

{{ select(3) }}

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

第 4 题

关于以下程序段,说法正确的是()

int x = 10;
cout << (x++) + (++x) << endl;

{{ select(4) }}

  • C++11 标准中,这是未定义行为,不同的环境有可能出现不同的结果
  • 22
  • 21
  • 20

第 5 题

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

{{ select(5) }}

  • 11110000
  • 10001111
  • 10010000
  • 11110001

第 6 题

三进制数2102(3)转换成十进制是:()

{{ 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
  • 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

第 12 题

执行以下代码后,输出结果是:()

char s[10] = "abcde";
int a = sizeof(s) / sizeof(s[0]);
int b = strlen(s);
cout << 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++) {
    // 需补充条件:
    if (__________________________) {
        str[i] = 'a' + (str[i] + 3 - 'z') - 1;
    } 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;