2024年6月 GESP C++ 3级认证考试真题(含编程操作题部分)
选 单选题(共 15 题,每题 2 分)
小杨⽗母带他到某培训机构给他报名参加CCF组织的GESP认证考试的第1级,那他可以选择的认证语⾔有(
)种。
下面流程图在yr输入2024时,可以判定yr代表闰年,并输出2月是29天,则图中菱形框中应该填入( )。
一般默认64位计算机系统中整型变量(int)还是32位,则整数能够表⽰的数据范围是( )。
下列代码将十进制转化成八进制,则横线上应填入( )。
#include <iostream>
using namespace std;
void decimal2octal(int decimal) {
int oct_number[100];
int i = 0;
while (decimal > 0) {
__________________________ //在此处填入代码
}
for (int j = i - 1; j >= 0; j--) {
cout << oct_number[j];
}
cout << endl;
}
二进制数101.11对应的十进制数是( )。
下列流程图的输出结果是( ) 。
下列代码的输出结果是( )。
#include <iostream>
using namespace std;
int main() {
int a = 12;
int result = a >> 2;
cout << result << endl;
return 0;
}
下列代码的输出结果是( )。
#include <iostream>
using namespace std;
int main() {
int a = 5;
int b = 10;
a = a ^ b;
b = a ^ b;
a = a ^ b;
cout << "a = " << a << ", b = " << b << endl;
return 0;
}
如果字符串定义为char str[] = "GESP";,则字符数组str的长度为( )。
在下列代码的横线处填写( ),可以使得输出是“7”。
#include <iostream>
using namespace std;
int main() {
int array[5] = {3,7,5,2,4};
int max = 0;
for(int i=0; i<5; i++)
if(______________) // 在此处填入代码
max = array[i];
cout << max << endl;
return 0;
}
小杨在做数学题,题目要求找出从1到35中能被7整除的数字,即[7, 14, 21, 28, 35],则横线处应填入哪个代
码?( )
#include <iostream>
using namespace std;
int main() {
int arr[35];
int count = 0;
for (int i = 1; i <= 35; i++) {
if (i % 7 == 0)
__________________________ // 在此处填入代码
}
for (int i = 0; i < count; i++)
cout << arr[i] << endl;
return 0;
}
已知字符 '0' 的ASCII编码的十进制表⽰为48,则执行下面C++代码后,输出是( )。
#include <iostream>
using namespace std;
int main() {
string s = "0629";
int n = s.length();
int x = 0;
for(int i = 0; i < n; i++)
x += s[i];
cout << x << endl;
return 0;
}
某小学男⼦篮球队招募新成员,要求加入球队的成员身高在135厘米以上(不含135厘米)。本次报名的⼈
员有10⼈,他们的身高分别是125、127、136、134、137、138、126、135、140、145。完善以下代码,求出本次球
队能够招募到新成员的⼈数?( )
#include <iostream>
using namespace std;
int main() {
int arr[10] = {125, 127, 136, 134, 137, 138, 126, 135, 140, 145};
int count = 0;
for(int i=0; i<10; i++)
__________________________ // 在此处填入代码
cout << count << endl;
return 0;
}
下面可以正确输出 They're planning a party for their friend's birthday. 的C++语句是?
( )
如果执行下面C++代码后,输出的结果是“gesp ccf org cn ”,则横线上应填入哪个代码?( )
#include <iostream>
using namespace std;
int main() {
string str = "gesp.ccf.org.cn";
string delimiter = ".";
string result="";
string token;
size_t found = str.find(delimiter);
while (found != string::npos) {
token = str.substr(0, found);
result += token;
result += " ";
__________________________ // 在此处填入代码
found = str.find(delimiter);
}
//最后一部分
result += str;
result += " ";
cout << result << endl;
return 0;
}
判 判断题(共 10 题,每题 2 分)
GESP测试是对认证者的编程能⼒进行等级认证,同一级别的能⼒基本上与编程语⾔无关。
整数-6的16位补码可用十六进制表⽰为FFFA。
补码的优点是可以将减法运算转化为加法运算,从⽽简化计算机的硬件设计。
字符常量'\0'常用来表⽰字符串结束,和字符常量'0'相同。
数组的所有元素在内存中可以不连续存放。
C++中可以对数组和数组的每个基础类型的元素赋值。
如果 为int类型的变量,且表达式((a | 3) == 3)的值为true,则说明 在从0到3之间(可能为0、可
能为3)。
执行下面C++代码后,输出的结果是8。
int a = 0b1010;
int b = 01100;
int c = a & b;
cout << c <<endl;
执行下面C++代码后,输出的结果不可能是89781。( )
#include <iostream>
#include <cstdlib> // 为了使用 rand() 和 srand()
#include <ctime> // 为了使用 time()
using namespace std;
int main() {
// 设置随机种子
srand(time(NULL));
int i = 1;
int s[5];
while(i <= 5)
{
int a = rand() % 10;
if(a % 3 == (i + 1) % 3)
s[i++] = a;
}
for(int i = 1; i <= 5; i++)
cout << s[i];
cout << endl;
return 0;
}
把整数3025从中剪开分为30和25两个数,此时再将这两数之和平方,计算结果⼜等于原数。(30 + 25) × (30
-
- = 55 × 55 = 3025,这样的数叫“雷劈数”。可以使用枚举的方法求出所有符合这样条件的四位数。( )
编 编程操作题(共 2 题,共 50 分)
试题名称:移位
时间限制:1.0 s | 内存限制:512.0 MB
输入格式
第⼀⾏包含⼀个正整数 。
输出格式
输出在偏移量为 的情况下,⼤写字母表 ABCDEFGHIJKLMNOPQRSTUVWXYZ 移位替换后的结果。
3.1.4 样例1
1 3
1 DEFGHIJKLMNOPQRSTUVWXYZABC
样例解释
当偏移量是3的时候,⼤写字母 A 会替换成 D,⼤写字母 Z 会替换成 C,总体来看,⼤写字母表
ABCDEFGHIJKLMNOPQRSTUVWXYZ 会被替换成 DEFGHIJKLMNOPQRSTUVWXYZABC。
数据范围
对于全部数据,保证有 。
试题名称:寻找倍数
时间限制:1.0 s | 内存限制:512.0 MB
输入格式
第⼀⾏包含⼀个正整数 ,代表测试⽤例组数。
接下来是 组测试⽤例。
对于每组测试⽤例,⼀共两⾏。其中,第⼀⾏包含⼀个正整数 ;第⼆⾏包含 个正整数,代表序列 。
输出格式
对于每组测试⽤例,如果存在 ( )满⾜对于所有 ( ) 是 的倍数,输出 Yes,否则输出 No。
3.2.4 样例1
1 2
2 3
3 1 2 4
4 5
5 1 2 3 4 5
1 Yes
2 No
样例解释
对于第⼀组数据,对于 ,满⾜ 是 和 的倍数。
数据范围
对于全部数据,保证有 。