通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"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]
阅读下列代码段:上述代码的编译结果是( )。
下列关于数据库设计的叙述中,正确的是( )。
有以下程序:程序运行时,输入的值在( )范围才会有输出
Python标准库_______中提供了计算MD5摘要
设有char a,b;若要通过a&b运算屏蔽掉a中的其
字符串“ab\n\\012\\\”的长度是______
关于字符常量,以下叙述正确的是( )。
完成远程登录的TCP/IP协议是:( )
设表的长度为n。在下列算法中,最坏情况下时间复杂度最高
交换线程通过三种途径来缩减已使用的内存页面:____、
创建外键约束时,如果要使在删除父表记录时子表对应记录也
Mysql锁的粒度越小,并发度就越 ___,开销越大,
create user语句创建用户帐号时______
下面的选项是关系数据库基本特征的是( )。
以下关于MAC的说法中错误的是
不属于计算机网络应用的是
下列内核的数据结构或程序中,分时系统实现时间片轮转调度
-0.4375 的 IEEE 754 单精度浮点数表示
定义int a[2][3];,表示数组a中的元素个数是
设x和y均为int型变量,则以下for循环中的scan
在C程序中,只能给指针变量,NULL值和_____值。
在以下给出的表达式中,与do-while(E)语句中的
预处理命令行都必须以_____号开始。
给定程序函数fun的功能是:比较两个字符串,将长的那个
(质因数分解)给出正整数 n,请输出将 n质因数分解的
由数字1, 1, 2, 4, 8, 8组成的不同的 4
1)输入:4 3输出:( )2)输入:2017 101
中国计算机学会于( )年创办全国青少年计算机程序设计竞
输入:11 3输出:( )
(棋盘覆盖问题)在一个 k k 2 × 2 个方格组成
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2