Logo

2026年3月 GESP C++ 3级

GESP · 3级 · 2026-03

60:00
满分 100
时长 60 分钟
27

2026年3月 GESP C++ 3级认证考试真题(含编程操作题部分)

答题卡 已答 0/27
已答 正确 错误 编程题

单选题(共 15 题,每题 2 分)

1

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

2

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

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

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

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

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

int x=10;
cout<<(x++) + (++x)<<endl;
5
位二进制下,十进制数-15 的补码是( )。
6

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

7

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

8

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

9

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

10

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

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

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

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

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

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

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

14

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

15

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

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

判断题(共 10 题,每题 2 分)

16

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

17

定义 double arr[10];,未手动初始化时,数组中所有元素的默认值为 0.0。

18

定义 int arr[] = {1,2,3};,则 sizeof(arr) 的结果为 12(int 占 4 字节)。

19

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

20

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

21

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

22

在 C++ 位运算中,各种不同的运算符有优先级的区分,使用括号能够解决优先级的问题。

23

由于在 0~255 范围内,char 类型和 int 类型可以互换,因此在这里 x 和 y 相等。

char x='1';
int y=1;
24

在C++语⾔中,表达式 ((0xf0 + 0x15) == 255) 的值为 true。

25

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

编程操作题(共 2 题,共 50 分)

26
编程操作题 25分

试题名称:⼆进制回⽂串

时间限制:1.0 s | 内存限制:512.0 MB

题目描述

对于⼀个正整数 ,我们将其转换为不含前导零的⼆进制表⽰,如果这个⼆进制序列从左向右读与从右向左读完全相
同,则称该数为⼆进制回⽂数。例如, 的⼆进制表⽰为 ,是⼆进制回⽂数; 的⼆进制表⽰为 ,
不是⼆进制回⽂数。
你的任务是:给定⼀个正整数 ,计算在 到 的范围内⼆进制回⽂数的数量。

输入格式

输⼊⼀⾏,包含⼀个正整数 。

输出格式

输出⼀⾏,包含⼀个数,表⽰在 到 的范围内⼆进制回⽂数的数量。

样例解释

样例 1 中, 到 范围内 、 、 、 、 、 是⼆进制回⽂数。

数据范围

27
编程操作题 25分

试题名称:凯撒密码

时间限制:1.0 s | 内存限制:512.0 MB

题目描述

凯撒密码是⼀种替换加密技术,明⽂中的所有字母都在字母表上向后(或向前)按照⼀个固定数⽬进⾏偏移后被替
换成密⽂。例如,当偏移量是 的时候,所有的字母 将被替换成 , 被替换成 , 被替换成 ,以此类推,
被替换成 , 被替换成 , 被替换成 , 被替换成 。这个加密⽅法是以罗马共和时期凯撒的名字命名
的,据称当年凯撒曾⽤此⽅法与其将军们进⾏联系。
但是和所有的利⽤字母表进⾏替换的加密技术⼀样,凯撒密码⾮常容易被破解,⽽且在实际应⽤中也⽆法保证通信
安全。
现在给你⼀个已破解的凯撒密码明⽂与密⽂,与⼀个有相同偏移量的未破解凯撒密码密⽂,请你帮忙破解它。

输入格式

输⼊共三⾏:
第⼀⾏包含⼀个字符串,表⽰已破解的凯撒密码明⽂;
第⼆⾏包含⼀个字符串,表⽰已破解的凯撒密码密⽂;
第三⾏包含⼀个字符串,表⽰待破解的凯撒密码密⽂。

输出格式

输出⼀⾏,包含⼀个字符串,表⽰待破解的凯撒密码对应的明⽂。

样例解释

样例 1 中,通过已破解的密码得出偏移量为 'D' - 'A' = 3,因此,对未破解部分进⾏逆向偏移:密⽂中的 W 对
应明⽂中的 T('W' - 3 = 'T'),密⽂中的 K 对应明⽂中的 H('K' - 3 = 'H'),以此类推。

数据范围

保证密码长度均不超过 ,所有字符串由⼤写字母组成。

已答 0/27