CCF GESP 2026年3月认证 C++ 3级

单选题
共 15 道 每题 2 分 共计 30 分
第 1 题

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

A

1

B

-1

C

49

D

+1 或者 −1

第 2 题

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

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

a,b 的值从始至终都没有改变。

B

a,b 的值实现了互换。

C

a,b 的值互换了以后,又还回去了,相当于没有变化。

D

a,b 的值最后和原值不一样,没有任何意义。

第 3 题

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

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

字符数组 str1str2 完全相同。

B
cout<<str1<<endl;
cout<<str2<<endl;

这段程序将输出不同的结果。

C

字符数组 str1str2 不相等

D

这两个赋值方式完全相同。

第 4 题

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

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

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

B

22

C

21

D

20

第 5 题

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

A

11110000

B

10001111

C

10010000

D

11110001

第 6 题

三进制数 $2102_{(3)}$​ 转换成十进制是:( )。

A

63

B

65

C

67

D

69

第 7 题

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

A

−73

B

−75

C

−77

D

75

第 8 题

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

A

64

B

72

C

80

D

120

第 9 题

补码的情况下,关于按位取反运算,用笔计算的情况下,以下说法错误的是:( )

A

~5 的结果是 −6(int 类型,32 位)

B

~0 的结果是 0(int 类型,32 位)

C

~(-3) 的结果是 2(int 类型,32 位)

D

~8 的结果是 −9(int 类型,32 位)

第 10 题

执行以下 C++ 代码后,sub 的值是( )。

string str = "GESP2026";  
string sub = str.substr(4, 2);
A

20

B

02

C

2026

D

026

第 11 题

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

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

4

B

6

C

24

D

30

第 12 题

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

char s[10] = "abcde"; 
int a = sizeof(s) / sizeof(s[0]);  
int b = strlen(s);  
cout << a - b;
A

4

B

5

C

6

D

10

第 13 题

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

A

找出 1∼100 之间所有能被 7 整除的数

B

找出 100∼200 之间的所有质数

C

计算 1+2+3+⋯+1000 的和

D

找出三位数中个位、十位、百位数字之和等于 10 的数

第 14 题

用枚举法解决 “鸡兔同笼问题:头共 35 个,脚共 94 只,求鸡和兔的数量”,以下枚举逻辑最合理的是:( )

A

枚举鸡的数量 x(0∼35),兔的数量 y=35−x,判断 2∗x+4∗y==94

B

枚举兔的数量 y(0∼94),鸡的数量 x=35−y,判断 2∗x+4∗y==94

C

枚举所有整数 x(0∼100)和 y(0∼100),判断 x+y==35 && 2*x+4*y==94

D

枚举脚的总数 sum(0∼94),判断 sum == 94

第 15 题

模拟 “字符串加密”:规则为 “每个字符 ASCII 码 +3,若超过 z (122) 则从 a 重新开始”,以下代码中正确的条件判断是:( )

for (int i = 0; i < str.length(); i++) {  
    // 需补充条件:
    _______________________
   else {
       str[i] += 3; 
   } 
}
A

if (str[i]> 122) str[i] = str[i] + 3 - 26;

B

if (str[i] > 122) str[i] = str[i] - 26;

C

if (str[i] + 3 > 122) str[i] = str[i] - 26;

D

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

单选题部分已到底了。