通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"CSP考试" 试卷中 CSP-S1提高级初赛试卷[2021] 中有题目如下:
第1题
#include <iostream> #include <string> using namespace std; char base[64]; char table[256]; void init() { for (int i = 0; i < 26; i++) base[i] = 'A' + i; for (int i = 0; i < 26; i++) base[26 + i] = 'a' + i; for (int i = 0; i < 10; i++) base[52 + i] = '0' + i; base[62] = '+', base[63] = '/'; for (int i = 0; i < 256; i++) table[i] = 0xff; for (int i = 0; i < 64; i++) table[base[i]] = i; table['='] = 0; } string encode(string str) { string ret; int i; for (i = 0; i + 3 <= str.size(); i += 3) { ret += base[str[i] >> 2]; ret += base[(str[i] & 0x03) << 4 | str[i + 1] >> 4]; ret += base[(str[i + 1] & 0x0f) << 2 | str[i + 2] >> 6]; ret += base[str[i + 2] & 0x3f]; } if (i < str.size()) { ret += base[str[i] >> 2]; if (i + 1 == str.size()) { ret += base[(str[i] & 0x03) << 4]; ret += "=="; } else { ret += base[(str[i] & 0x03) << 4 | str[i + 1] >> 4]; ret += base[(str[i + 1] & 0x0f) << 2]; ret += "="; } } return ret; } string decode(string str) { string ret; int i; for (i = 0; i < str.size(); i += 4) { ret += table[str[i]] << 2 | table[str[i + 1]] >> 4; if (str[i + 2] != '=') ret += (table[str[i + 1]] & 0x0f) << 4 | table[str[i + 2]] >> 2; if (str[i + 3] != '=') ret += table[str[i + 2]] << 6 | table[str[i + 3]]; } return ret; } int main() { init(); cout << int(table[0]) << endl; int opt; string str; cin >> opt >> str; cout << (opt ? decode(str) : encode(str)) << endl; return 0; }
假设输入总是合法的(一个整数和一个不含空白字符的字符串,用空格隔开),对于任意不含空白字符的字符串str1,先执行程序输入“0 str1”,得到输出的第二行记为str2;再执行程序输入“1 str2”,输出的第二行必为str1。
正确
错误
所属试卷:CSP-S1提高级初赛试卷[2021]
下列语句中,错误的是。
AWT中用来表示对话框的类是( )。
在 32 位计算机上执行下列 C 语言代码段后,ui
下列关于 CPU 中的数据通路和控制器的叙述中,错误的
下列不属于数据库设计任务的是( )。
给定程序中,函数fun的功能是:将形参n所指变量中,各
列表可以作为集合的元素。
表达式eval(‘500//10’)的结果是。
#编写一个函数,从键盘上输入两个数,求最大公约数和最小
以下printf语句中的负号的作用是_________
有以下程序程序运营后的输出结果是____
命令组合(命令表)将 ______ 来执行命令。
Linux主要采用了 和 两种动态内存管理
Linux系统使用哪个命令更改文件所有者( )
网络管理的重要任务是:_____和________。
MySQL客户端程序 _____用于数据库的备份。
在Student表的Sname列上建立一个唯一索引的S
当在一个有序的顺序存储表上查找一个数据时,即可用折半查
必须要由网络管理员手动配置的是
关系数据模型哪些优点?( )
(15 分)假定计算机 M 字长为 16 位,按字节编
(容器分水)有两个容器,容器 1 的容量为为 a 升,
C语言中,二维数组在内存中的存放方式为按_____优先
将数组a的首地址赋给指针变量p的语句是_____。
预处理命令行都必须以_____号开始。
下列叙述中正确的是
有以下程序, 程序运行后的输出结果是( )。
(子矩阵) 给输入一个 n1*m1 的矩阵 a,和 n
输入: 5 4 -6 -11 6 -59 22 -6
已知 6 个结点的二叉树的先根 +遍历是 1 2 3
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2