通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"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; }
假设输入总是合法的(一个整数和一个不含空白字符的字符串,用空格隔开),程序总是先输出一行一个整数,再输出一行一个字符串。
正确
错误
所属试卷:CSP-S1提高级初赛试卷[2021]
下列程序执行后,输出的结果是。
给定 7 个不同的关键字,能够构造的不同 4 阶 B
若定义cin>>str;,当输入Object Wind
#编写程序,计算所有三位数水仙花数的和并输出求和结果。
已知函数定义def demo(x,y,op):retu
已知函数定义 def func (**p):retur
用switch语句编程实现以下函数关系:参考答案:
下面程序运行结果是___________。
若x=0123,则表达式(5+(int)(x)&(-2
执行下面程序段后,k的值为________。
软件系统总体结构图的作用是
给定程序MODI1.C中函数fun的功能是:将s所指字
将当前目录下的bin目录和hello、hello.c文
执行命令 ls –l 时,某行显示如下:
如果你的umask设置为022,缺省的你创建的文件的权
下面哪个Linux命令可以一次显示一页内容?
MySQL中gbk字符集的默认校对规则是 。
如果MySQL服务名为MySQL56,则在Window
使用insert、updeat和delete语句对用户
MySQL安装时默认端口为( )。
在DELETE触发程序中,可使用( )关键字引用被删除
从GROUP BY分组的结果集中再次用条件表达式进行筛
在n个结点的顺序表中,算法的时间复杂度是O(1)的操作
下面关于哈希(Hash,杂凑)查找的说法正确的是( )
(RMQ 区间最值问题)给定序列a0,⋯,an-1,和
当输入为“2 -65536 2147483647”时,
阅读以下程序该程序在编译时产生错误,其出错原因是
对于入栈顺序为a, b, c, d, e, f, g的
结点数为 5的不同形态的二叉树一共有_____种。(结
输出: ________________
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2