通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"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; }
假设输入总是合法的(一个整数和一个不含空白字符的字符串,用空格隔开),设输入字符串长度为n,encode函数的时间复杂度为( )。
O(√n)
O(n)
O(nlogn)
O(n^2)
所属试卷:CSP-S1提高级初赛试卷[2021]
有如下程序(类构造、析构函数执行相关),运行这个程序的
有以下程序,在横线应添加。
假定MyClass为一个类,那么下列的函数说明中,
语句int *p=&k;,与其等效的语句序列是。
计算机系统中的进程之间往往需要相互协作以完成一个任务。
编写代码,获得用户输入的一个数字(1~12),输出对应
给定程序MODI1.C中函数fun的功能是:计算n!。
下列叙述中,不属于设计准则的是( )。
若有定义语句接着执行以下选项中的语句,则能正确执行的语
在Python中定义类时,与运算符“//”对应的特殊方
在循环语句中,_______语句的作用是提前进入下一次
己知x为非空列表,那么表达式x.sort==sor
当运行以下程序时,从键盘输入:ab<回车>C<回车>d
以下函数fun的功能是:统计用数字0~9可以组成多少个
在C语言源程序中,一个变量代表___________。
将/home/ixdba目录做归档压缩,压缩后生成ix
下面哪个系统目录中存放了系统引导、启动时使用的一些文件
grep -E '[Hh]enr(y|ietta)'
对于Shell脚本程序,若输入参数数量多于9个,则程序
在vi编辑器中的命令模式下,重复上一次对编辑的文本进行
用图树型结构表示实体类型及实体间联系的数据模型称为
在INSERT触发器中,可以引用一个名为 ______
grant语句可以跟下列with选项表示对用户的权限进
BBS的含义是
有关虚拟局域网的概念,下面哪个说法不正确
x*=y+8等价于x=x*(y+8)。
若有以下程序则程序的输出结果是
如下图所示,共有 13个格子。对任何一个格子进行一次操
十进制小数125.125对应的8进制数是:
书架上有 21 本书,编号从 1 到 21 ,从其中选
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2