试卷总分:100分
选择题 15题 30分
判断题 10题 20分
编程题 2题 50分
a,b是整型变量,各自有互不相同的初始值。下列程序实现了什么效果( )。
a=a^b; b=a^b; a=a^b;
关于下列正确的程序段,说法正确的是( )。
char str1[] = "Hello"; char str2[] ={'H','e','l','l','0'};
关于以下程序段,说法正确的是( )。
int x=10; cout<<(x++) + (++x)<<endl;
执行以下 C++ 代码后, sub 的值是( )。
string str = "GESP2026"; string sub = str.substr(4, 2);
执行以下代码后,输出结果是:( )。
int arr[] = {5, 10, 15, 20, 25, 30}; int count = sizeof(arr) / sizeof(arr[0]); cout << count;
char s[10] = "abcde"; int a = sizeof(s) / sizeof(s[0]); int b = strlen(s); cout << a - b;
模拟 “字符串加密”:规则为 “每个字符 ASCII 码 + 3,若超过 z (122) 则从 a 重新开始”,以下代码中正确的条件判断是:( )
for (int i = 0; i < str.length(); i++) { // 需补充条件: _______________________ else { str[i] += 3; } }
下面的流程图是用来求 1+2+3+…+10 的和。请判断:这个流程图的逻辑正确还是错误?
下面流程图的功能是计算 5 对 2 取余数,输出结果为 1。
由于在 0~255 范围内, char 类型和 int 类型可以互换,因此在这里 x 和 y 相等。
char x='1'; int y=1;
对于一个正整数 ,我们将其转换为不含前导零的二进制表示,如果这个二进制序列从左向右读与从右向左读完全相同,则称该数为二进制回文数。例如,9 的二进制表示为 (1001)2,是二进制回文数;12 的二进制表示为 (1100)2,不是二进制回文数。
你的任务是:给定一个正整数 n,计算在 1 到 n 的范围内二进制回文数的数量。
输入一行,包含一个正整数 n。
输出一行,包含一个数,表示在 1 到 n 的范围内二进制回文数的数量。
1≤n≤10^5
15
6
凯撒密码是一种替换加密技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是 3 的时候,所有的字母 A 将被替换成 D,B 被替换成 E,C 被替换成 F,以此类推,W 被替换成 Z,X 被替换成 A,Y 被替换成 B,Z 被替换成 C。这个加密方法是以罗马共和时期凯撒的名字命名的,据称当年凯撒曾用此方法与其将军们进行联系。
但是和所有的利用字母表进行替换的加密技术一样,凯撒密码非常容易被破解,而且在实际应用中也无法保证通信安全。
现在给你一个已破解的凯撒密码明文与密文,与一个有相同偏移量的未破解凯撒密码密文,请你帮忙破解它。
输入共三行:
第一行包含一个字符串,表示已破解的凯撒密码明文;
第二行包含一个字符串,表示已破解的凯撒密码密文;
第三行包含一个字符串,表示待破解的凯撒密码密文。
输出一行,包含一个字符串,表示待破解的凯撒密码对应的明文。
保证密码长度均不超过1000,所有字符串由大写字母组成。
ABCDEFGVWXYZ
DEFGHIJYZABC
WKHTXLFNEURZQIRAMXPSVRYHUWKHODCBGRJ
THEQUICKBROWNFOXJUMPSOVERTHELAZYDOG