通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"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; }
假设输入总是合法的(一个整数和一个不含空白字符的字符串,用空格隔开),当输入为“1 SGVsbG93b3JsZA==”时,输出的第二行为“HelloWorld”。
正确
错误
所属试卷:CSP-S1提高级初赛试卷[2021]
阅读下列一个支持多线程并发操作的堆栈类代码段:在下划线
下列数据结构中,属于非线性结构的是( )。
C语言中的标识符分为关键字、预定义标识符和用户标识符,
设有以下程序段:要引用结构体变量std中的color成
有以下程序段:当执行上述程序段,并从键盘输入:name
请在下面的横线处填上适当内容,以使类的定义完整。
在Python中,不论类的名字是什么,构造方法的名字都
已知x是个列表对象,那么执行语句y=x[:]之后,对y
表达式list(range(5))的值为_______
已知x=[3, 3,4],那么表达式id(x[0])=
用switch语句编程实现以下函数关系:参考答案:
若s是int型变量,且s=7,则表达式s/2+(s+1
若有定义语句int a, b;double x;则下列
甲乙双方均采用后退N帧协议(GBN)进行持续的双向数据
假设linux分配给光驱的设备名是/dev/cdrec
安装Linux系统对硬盘分区时,必须有两种分区类型:
网络管理的重要任务是:_____和________。
MySql数据库中具体实现备份数据库的方法很多,可以分
DNS的作用是
在串行通信中采用位同步技术的目的是
下列事件或操作中,可能导致进程 P 由执行态变为阻塞态
已知无向图G如下所示,使用克鲁斯卡尔(Kruskal)
假设变量a、b均为整型,表达式(a=5,b=2,a>b
设x和y均为int型变量,则以下for循环中的scan
设栈的存储空间为S(1:50),初始状态为top-0,
输入:5 6输出:( )
是目前互联网上常用的E-mail服务协议。
原字符串中任意一段连续的字符组成的新字符串称为子串。则
( )是目前互联网上常用的 E-mail 服务协议
输出:_____________
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2