通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"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]
下列关于C++流的描述中,错误的是
下列有关模板的叙述中,正确的是
关系的实体完整性要求关系中不能为空的属性是
下列关于类和对象的叙述中,错误的是。
下列关于函数重载的叙述中,错误的是。
编写代码,获得用户输入的一个合法算式并输出结果。参考答
某计算机按字节编址,采用页式虚拟存储管理方式,虚拟地址
(读者自行创建,注意每行第一个逗号后面有空格),其内容
在数据管理的三个发展阶段中,数据的共享性好且冗余度最小
在最坏情况下( )。
给定程序MODI1.C中函数fun的功能是:从s所指字
设变量x为long int型并已正确赋值,以下表达式中
有以下程序(注:字符a的ASCII码值为97):程序运
对定义重载函数的下列要求中,______是错误的。
下面程序的运行结果是___________。
对于一个主机域名www、hava、gxou、com、c
增加一个用户的命令是______
Linux系统下经常使用的两种桌面环境是:____
你使用命令“vi /etc/inittab”查看该文件
Linux系统的开发模型是 ______ 。
在MySQL中,允许从一个集合中取得多个值的数据类型是
请设计一个队列,要求满足:①初始时队列为空;②入队时,
常见的软件概要设计方法有 3 大类:以数据流图为基础构
软件生命周期可分为定义阶段、开发阶段和维护阶段,下面不
输入 1:4 3输出 1:____输入 2:2017
(最大矩阵和 )给出 M 行 N 列的整数矩阵,就最大
输入: 18输出: ___________
输入: 16输出: ______________
LZW 编码是一种自适应词典编码。在编码的过程中,开始
输入: ABCDEFGuvwxyz输出: ______
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2