通过海量题库、编程比赛和实时排名,系统化提升您的编程能力。
"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]
下列方法中与Applet显示无关的是( )。
函数fun的功能是:将s所指字符串中ASCII值为偶数
设有定义int x=0,*p;立即执行以下语句,正确的
以下选项中,合法的一组C语言数值常量是。
C语言源程序名的后缀是( )。
请在下面程序的横线处填上适当内容,以使程序完整,并使程
已知 x = list(range (10)),则表达
表达式 list(zip([1,2],[3,4]))的
若程序中有下面的说明和定义:则会发生的情况是( )。
已有如下定义和输入语句,若要求a1,a2,a3,c1,
能正确表达数学逻辑关系“0<a<1或0<b<1”的C语
有下列程序:程序运行后的输出结果是( )。
什么是链接?符号链接与硬链接的区别是什么?答:链接是指
综述Linux系统的文件权限及其管理。答:Linux用
对于Shell脚本程序,若输入参数数量多于9个,则程序
对于System V类型的共享内存页面,Linux基于
下面除了( )之外其它都是属于数据模型的三要素。
若某线性表最常用的操作是存取任一指定序号的元素和在最后
用二叉链表存储包含n个结点的二叉树时,结点的2n个指针
下列说法中不对的是:
什么是黑盒测试法?[答案解析]黑盒测试法把程序看成一个
模块化,信息隐藏,抽象和逐步求精的软件设计原则有助于得
可行性研究主要集中在以下四个方面 、 、
设有int x=11,则表达式(x++ * 1/3)的
若有以下定义,则计算表达式y+=y-=m*=y后的y值
输入 :abacaba输出 :________
(交通中断)有一个小国家,国家内有 n座城市和 m条双
下列四个不同进制的数中,与其它三项数值上不相等的是(
输入:Hello, my name is Lostmo
一棵具有 5 层的满二叉树中结点数为 ( ) 。
更多选择题
更多填空题
第十章 C++流
第九章 C++模板
第八章 C++运算符重载
C++语言程序设计真题5
C++语言程序设计真题4
C++语言程序设计真题3
C++语言程序设计真题2