2024年9月 GESP C++ 4级认证考试真题(含编程操作题部分)
选 单选题(共 15 题,每题 2 分)
在 C++ 中,( )正确定义了一个返回整数值并接受两个整数参数的函数。
在C++中,形参与实参的关系描述正确的是( )。
运行以下代码,屏幕上将输出( )。
#include <iostream>
using namespace std;
int var = 100;
void function() {
int var = 200;
cout << var << " ";
cout << ::var << " ";
}
int main() {
cout << var << " ";
function();
var += 100;
cout << var << " ";
return 0;
}
运行下面代码,屏幕上输出是( )。
int arr[3] = {24, 9, 7};
int* p = arr;
p++;
cout << *p << endl;
运行下面代码片段的结果是( )。
int x = 20;
int y = 24;
int* p = &x;
int* q = &y;
p = q;
在 C++ 中,( )正确定义一个名为student的结构体,其中包含一个name字符数组和一个age整数?
在 C++ 中,( )正确声明了一个 3 行 4 列的二维数组。
一个二维数组定义为 int arr[3][4];(假设一个int变量占4个字节),则int arr[0]占用( )个字节
的内存。
下面代码采用递推算法来实现整数 的阶乘( ),则横线上应填写( )。
int factorial(int n) {
int result = 1;
for (int i = 2; i <= n; i++) {
________________________________ // 在此处填入代码
}
return result;
}
在排序算法中,稳定性指的是( )。
下面代码实现了冒泡排序函数,则横线上应填写( )。
//交换数组arr的第i个元素和第j个元素
void swap(vector<int> &arr, int i, int j) {
int tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
}
int bubble_sort(vector<int> &arr) {
for (int i = arr.size() - 1; i > 0; i--) {
bool flag = false; // 标志位
________________________________ { // 在此处填入代码
if (arr[j] > arr[j + 1]) {
swap(arr, i, j);
flag = true;
}
}
if (!flag)
break; // 此轮“冒泡”未交换任何元素
}
}
上一题算法的时间复杂度为( )。
下面代码实现了插入排序函数(升序),则横线上应填写( )。
void insertion_sort(vector<int> &nums) {
for (int i = 1; i < nums.size(); i++) {
int base = nums[i], j = i - 1;
________________________________ { // 在此处填入代码
nums[j + 1] = nums[j];
j--;
}
nums[j + 1] = base;
}
}
小杨用文件重定向实现在log.txt文件中输出⽇志,则下面横线上应填写( )。
#include <iostream>
#include <fstream>
#include <string>
using namespace std;
int main() {
ofstream log_file("log.txt");
streambuf* original_cout = cout.rdbuf();
cout.rdbuf(log_file.rdbuf());
___________________________________ // 在此处填入代码
cout.rdbuf(original_cout); // 恢复原始的标准输出缓冲区
return 0;
}
运行下面的代码,屏幕上将输出( )。
#include <iostream>
using namespace std;
int divide(int a, int b) {
if (b == 0) {
throw runtime_error("division by zero error ");
}
return a / b;
}
int main() {
int x = 10;
int y = 0; // 设为 0 会导致除零错误
try {
int result = divide(x, y);
cout << "result: " << result << endl;
} catch (const runtime_error& e) {
cout << "caught an exception: " << e.what() << endl;
}
return 0;
}
判 判断题(共 10 题,每题 2 分)
代码int a = 10; int* p = &a;可以正确定义指针和初始化指针。
在 C++ 中,引用传递允许函数修改传递给它的参数的值。
指针的大小与其所指向的变量的数据类型的大小相同。
二维数组的行的大小的必须在定义时确定,列的大小可以动态变化。
递推算法通过逐步求解当前状态和前一个或几个状态之间的关系来解决问题。
选择排序是稳定的排序算法。
插入排序的时间复杂度总是比冒泡排序低。
在 C++ 中,如果没有捕获到异常(没有匹配的 catch 块),程序会继续执行⽽不会终⽌。
以下代码用递推法求斐波那契数列的第 项,时间复杂度为指数级。
int fibonacci(int n) {
if (n == 0) return 0;
if (n == 1) return 1;
int f0 = 0; // F(0)
int f1 = 1; // F(1)
int current;
for (int i = 2; i <= n; i++) {
current = f0+ f 1; / / F(n) = F(n-1) + F(n-2)
f0 = f1;
f1 = current;
}
return current;
}
执行下面C++代码后,输出的是20。
int point(int* p){
return *p * 2;
}
int main() {
int a = 10;
int* p = &a;
*p = point(p);
cout << *p << endl;
}
编 编程操作题(共 2 题,共 50 分)
试题名称:⿊⽩⽅块
时间限制:1.0 s | 内存限制:512.0 MB
输入格式
第⼀⾏包含⼀个正整数 ,代表测试⽤例组数。
接下来是 组测试⽤例。对于每组测试⽤例,⼀共 ⾏。
第⼀⾏包含两个正整数 ,含义如题⾯所⽰。
之后 ⾏,每⾏⼀个长度为 的 串,代表⽹格图第 ⾏格⼦的颜⾊,如果为 ,则对应格⼦为⽩⾊,否则为⿊
⾊。
输出格式
对于每组测试⽤例,如果存在,输出 Yes,否则输出 No。
3.1.4 样例1
1 3
2 1 4
3 0110
4 5 5
5 00000
6 01100
7 01100
8 00001
9 01100
10 5 5
11 00000
12 01100
13 01110
14 00001
15 01100
试题名称:区间排序
时间限制:1.0 s | 内存限制:512.0 MB
输入格式
第⼀⾏包含⼀个正整数 ,含义如题⾯所⽰。
第⼆⾏包含 个正整数 ,代表序列。
第三⾏包含⼀个正整数 ,代表排序次数。
之后 ⾏,每⾏包含两个正整数 , ,代表将区间 内所有数字进⾏升序排序。
输出格式
输出⼀⾏包含 个正整数,代表多次升序排序后的序列。
3.2.4 样例1
1 5
2 3 4 5 2 1
3 3
4 4 5
5 3 4
6 1 3
1 1 3 4 5 2
第⼀次升序排序后,序列为 ;
第⼆次升序排序后,序列为 ;
第三次升序排序后,序列为 ;
对于全部数据,保证有 。