Logo

2024年12月 GESP C++ 4级

GESP · 4级 · 2024-12

60:00
满分 100
时长 60 分钟
27

2024年12月 GESP C++ 4级认证考试真题(含编程操作题部分)

答题卡 已答 0/27
已答 正确 错误 编程题

单选题(共 15 题,每题 2 分)

1

下面的语句中,( )正确定义了一个计算浮点数 的平方( )的函数,并成功调用该函数。

2

下面代码的描述中,正确的是( )。

void n_chars(char c, int n) {
    while (n-- > 0)
    cout << c;
}
char my_char = 'w';
int times = 5;
n_chars(my_char, times);
3

给定以下代码,

void func(int& x) {
    x = x * 2;
}
int a = 5;
func(a);

执行上述代码后,变量a的值为( )。

4

运行下面代码,屏幕上输出是( )。

double* p_arr = new double [3];
p_arr[0] = 0.2;
p_arr[1] = 0.5;
p_arr[2] = 0.8;
p_arr += 1;
cout << p_arr[0] << endl;
p_arr -= 1;
delete p_arr;
5

运行下面代码片段后,x和*p的结果分别是( )。

int x = 20;
int* p = &x;
*p = *p + 2;
6

下面的描述中,( )不能正确定义一个名为Student的结构体以及一个包含20个元素的结构数组。

7

假定整型是32位,对一个 行 列的二维整数数组array,假设数组第一个元素在内存中的地址为
0x7ffee4065820,则第2行第2个元素的地址&array[1][1]为( )。

int array[2][3] = {
    {0, 1, 2},
    {3, 4, 5}
};
8

下面( )正确定义二维数组。

9

下面代码采用递推算法来计算斐波那契数列 ,则横线上应填写( )。

int fib(int n) {
    if (n == 0 || n == 1)
    return n;
    int f1 = 0;
    int f2 = 1;
    int result = 0;
    for (int i = 2; i <= n; i++) {
        ________________________________ // 在此处填入代码
    }
    return result;
}
10

下面关于排序算法(冒泡排序、插入排序和选择排序)的描述中,不正确的是( )。

11

冒泡排序的第一轮操作是从左到右遍历数组,通过两两比较相邻元素,将当前最大的元素移动到末尾。给
定数组arr[]={4, 1, 3, 1, 5, 2},执行第一轮冒泡排序后数组arr中的内容为( )。

12

给定如下代码,其时间复杂度为( )。

int cellRecur(int n) {
    if (n == 1)
    return 1;
    return cellRecur(n - 1) + cellRecur(n - 1) + 1;
}
13

下面代码实现了插入排序函数,则横线上应填写( )。

void insertion_sort(vector<int> &nums) {
    for (int i = 1; i < nums.size(); i++) {
        ________________________________ { // 在此处填入代码
            while (j >= 0 && nums[j] > base)
            nums[j + 1] = nums[j];
            j--;
        }
        nums[j + 1] = base;
    }
}
14

下面哪种方式不能实现将字符串"Welcome to GESP!"输出重定向到文件log.txt( )。

15

运行下面的代码,将出现什么情况?( )

double hmean(double a, double b) {
    if (a == -b )
    throw runtime_error("Runtime error occurred");
    return 2.0*a*b/(a + b);
}
int main() {
    double x = 10;
    double y = -10;
    try {
        int result = hmean(x, y);
        cout << "hmean: " << result << endl;
    }
    catch (const runtime_error& e) {
        cout << "Caught: " << e.what() << endl;
    } catch (...) {
        cout << "Caught an unknown exception." << endl;
    }
    return 0;
}

判断题(共 10 题,每题 2 分)

16

在 C++ 中,下面代码可以正确定义指针和初始化指针。

int* ptr;
*ptr = 10;
17

一个函数必须在调用之前既声明⼜定义。

18

函数参数可以通过值传递、引用传递和指针传递,这样函数内对参数的修改可以直接修改传入变量的值。

19

int arr[3][]是一个正确的二维数组的声明。

20

递推是一种通过已知的初始值和递推公式,逐步求解目标值的算法。

21

某算法的递推关系式为 ( 为正整数)及 ,则该算法的时间复杂度为 。

22

冒泡排序的平均时间复杂度为 ,但最优情况下为 。

23

冒泡排序和插入排序都是稳定的排序算法。

24

选择排序是稳定的排序算法。

25

在 C++语⾔中,如果一个函数可能抛出异常,那么一定要在try ⼦句里调用这个函数。

编程操作题(共 2 题,共 50 分)

26
编程操作题 25分

试题名称:Recamán

时间限制:1.0 s | 内存限制:512.0 MB

题目描述

⼩杨最近发现了有趣的 Recamán 数列,这个数列是这样⽣成的:
数列的第⼀项 是 ;
如果 是正整数并且没有在数列中出现过,那么数列的第 项 为 ,否则为 。
⼩杨想知道 Recamán 数列的前 项从⼩到⼤排序后的结果。⼿动计算⾮常困难,⼩杨希望你能帮他解决这个问题。

输入格式

第⼀⾏,⼀个正整数 。

输出格式

⼀⾏, 个空格分隔的整数,表⽰ Recamán 数列的前 项从⼩到⼤排序后的结果。

样例解释

对于样例 1, :

,不是正整数,因此 ;
,不是正整数,因此 ;
,是正整数,且没有在数列中出现过,因此 ;

数据范围

对于所有数据点,保证 。

27
编程操作题 25分

试题名称:字符排序

时间限制:1.0 s | 内存限制:512.0 MB

输入格式

第⼀⾏包含⼀个正整数 ,代表测试数据组数。
对于每组测试数据,第⼀⾏包含⼀个正整数 ,含义如题⾯所⽰。
之后 ⾏,每⾏包含⼀个字符串 。

输出格式

对于每组测试数据,如果存在满⾜条件的排列顺序,输出 1,否则输出 0。

样例解释

对于第⼀组测试数据,⼀种可⾏的排列顺序为 aa+ac+de,构成的字符串 为 aaacde,满⾜条件。
对于全部数据,保证有 ,每个字符串的长度不超过 。

已答 0/27