CCF编程能力等级认证GESP—C++3级—20250927
单选题(每题 2 分,共 30 分)
1、执行以下C++代码后, c 的数值是( )。
int a = 10, b = 3;
double c = a / b;
A. 3.33333
B. 3.333
C. 3.0
D. 3.3
正确答案:C
2、下列C++表达式的结果为 true 的是( )。
A. (5 <= 5) && (7 < 5)
B. !(10 > 5)
C. (10 != 10) || (5 >= 3)
D. (5 == 3) && (4 > 2)
正确答案:C
3、以下关于C++数组的说法,错误的是( )。
A. 数组的下标通常从 0 开始。
B. int arr[5]; 声明了一个包含5个整数的数组。
C. 数组的大小必须在编译时确定,不能使用变量定义大小。
D. 可以通过 arr[5] 来访问 int arr[5]; 数组的最后一个元素。
正确答案:D
4、执行以下C++代码后,变量 sum 的值是( )。
int sum = 0;
for (int i = 1; i <= 5; i += 2) {
sum += i;
int sum = 0;
}
A. 6
B. 9
C. 15
D. 死循环
正确答案:B
5、要正确定义一个返回两个整数中较大值的函数 max ,应该使用( )。
A. void max(int a, int b) { return a > b ? a : b; }
B. int max(int a, int b) { if (a > b) return a; else return b; }
C. int max(a, b) { if (a > b) return a; else return b; }
D. void max(a, b) { cout << (a > b ? a : b); }
正确答案:B
6、执行以下C++代码后,数组 arr 的内容是( )。
int arr[4] = {1, 2, 3};
arr[3] = arr[0] + arr[2];
A. {1, 2, 3, 3}
B. {1, 2, 3, 4}
C. {1, 2, 3, 5}
D. {1, 2, 3, 6}
正确答案:B
7、以下关于C++函数的描述,正确的是( )。
A. 函数必须要有参数。
B. 函数通过 return 语句只能返回一个值。但是可以通过很多间接的方式返回多个值。
C. main 函数可以被其他函数调用。
D. 函数的定义可以直接嵌套,即一个函数内部可以真正定义另一个函数。
正确答案:B
8、以下C++代码 count++ 执行的次数是( )。
int i = 10;
int count=0;
while (i > 0) {
i -= 3;
continue;
count++;
}
A. 2
B. 3
C. 4
D. 0
正确答案:D
9、以下C++代码段的输出是( )。
for (int i = 0; i < 4; i++) {
for (int j = 0; j <= i; j++) {
cout << j;
}
cout << "#";
}
A. 0#01#012#0123#
B. 1#12#123#1234#
C. 0#1#2#3#
D. 0#01#012#01243#
正确答案:A
10、以下关于C++变量作用域的说法,错误的是( )。
A. 在 for 循环语句中声明的变量,其作用域仅限于该循环体内。
B. 在函数内部声明的变量(局部变量),仅在函数内部有效。
C. 在所有函数外部声明的变量,在整个程序中都有效。
D. 不同函数中的局部变量可以同名,它们代表不同的内存单元
正确答案:C
11、关于以下代码的说法正确的是( )。
int reversed = 0;
while (x != 0) {
int digit = x % 10;
x /= 10;
reversed = reversed * 10 + digit;
}
A. 能够反转任何位数的整数
B. 能够反转的最大位数正整数是 2147483647
C. 能够反转的最大位数正整数是 2147483648
D. 能够反转的最大位数正整数是 1463847412
正确答案:D
12、以下C++代码试图查找数组中的最大值,划线处应填入( )。
#include <iostream>
using namespace std;
int findMax(int arr[], int size) {
int maxVal =
________; // 划线处
for (int i = 1; i < size; i++) {
if (arr[i] > maxVal) {
maxVal = arr[i];
}
}
return maxVal;
}
A. 0
B. arr[-1]
C. arr[0]
D. size
正确答案:C
13、以下关于C++函数的说法,正确的是( )。
A. 函数参数传递只有值传递一种方式。
B. 函数的形参在函数调用结束后依然占用内存空间
C. 没有返回值的函数必须声明为 void 类型,且不能包含 return 语句
D. C++11 及之后标准要求函数必须显式声明返回类型,不允许默认返回 int
正确答案:D
14、以下C++代码中存在几处错误( )。
#include <iostream>
using namespace std;
int main() {
const int SIZE = 5;
int arr[SIZE];
for (int i = 0; i <= SIZE; i++) {
arr[i] = i * 2;
}
cout << arr[SIZE] << endl;
return 0;
}
A. 0处
B. 1处
C. 2处
D. 3处
正确答案:C
15、以下关于C++中 string 类和字符数组( char[] )的说法,错误的是( )。
A. string 对象可以使用 = 进行赋值,而字符数组需要使用 strcpy。
B. string 对象的长度可以使用 length() 成员函数获取,而字符数组需要使用 strlen() 函数。
C. string 对象在内存中是动态分配空间的,因此可以自动处理字符串长度的变化。
D. string 对象和字符数组都可以使用 == 运算符来直接比较两个字符串的内容是否相同。
正确答案:D
判断题(每题 2 分,共 20 分)
1、表达式 sizeof(‘a’) 的结果总是 1 ,因为 ‘a’ 是一个字符。
正确答案:错误
2、在C++中,所有全局变量如果没有显式初始化,都会被自动初始化为0。
正确答案:正确
3、 do { … } while (false); 循环体内的语句至少会被执行一次。
正确答案:正确
4、在C++中, ++i 是一个左值表达式,而 i++ 是一个右值表达式。
正确答案:正确
5、对于 enum Color { RED, GREEN, BLUE };, RED 的类型是 int
正确答案:错误
6、#define SQUARE(x) x * x 是一个安全的宏定义, SQUARE(2+3) 会正确计算出 25 。
正确答案:错误
7、在C++中, char 类型的取值范围总是 -128 到 127。
正确答案:错误
8、表达式 a > b ? a : b = 10; 一定是合法的C++代码。
正确答案:错误
9、#include “file.h” 和 #include <file.h> 在编译器查找头文件时的搜索策略是完全相同的。
正确答案:错误
10、在同一个作用域内, extern 声明的变量可以多次定义。
正确答案:错误
编程题 (每题 25 分,共 50 分)
数组清零
【问题描述】
小 A 有一个由n个非负整数构成的数组
a
=
[
a
1
,
a
2
,
.
.
.
,
a
n
]
a = [a_1, a_2, ..., a_n]
a=[a1,a2,...,an]。他会对数组a重复进行以下操作,直到数组a只包含0。在一次操作中,小 A 会依次完成以下三个步骤:
- 在数组a中找到最大的整数,记其下标为k。如果有多个最大值,那么选择其中下标最大的。
- 从数组a所有不为零的整数中找到最小的整数 a j a_j aj。
- 将第一步找出的 a k a_k ak减去 a j a_j aj。
例如,数组
a
=
[
2
,
3
,
4
]
a = [2, 3, 4]
a=[2,3,4]需要7次操作变成
[
0
,
0
,
0
]
[0, 0, 0]
[0,0,0]:
[
2
,
3
,
4
]
−
>
[
2
,
3
,
2
]
−
>
[
2
,
1
,
2
]
−
>
[
2
,
1
,
1
]
−
>
[
1
,
1
,
1
]
−
>
[
1
,
1
,
0
]
−
>
[
1
,
0
,
0
]
−
>
[
0
,
0
,
0
]
[2, 3, 4] -> [2, 3, 2] -> [2, 1, 2] -> [2, 1, 1] -> [1, 1, 1] -> [1, 1, 0] -> [1, 0, 0] -> [0, 0, 0]
[2,3,4]−>[2,3,2]−>[2,1,2]−>[2,1,1]−>[1,1,1]−>[1,1,0]−>[1,0,0]−>[0,0,0]
小 A 想知道,对于给定的数组a,需要多少次操作才能使得a中的整数全部变成0。可以证明,a中整数必然可以在有限次操作后全部变成0。你能帮他计算出答案吗?
【输入格式】
第一行,一个正整数n,表示数组a的长度。
第二行,n个非负整数
a
1
,
a
2
,
.
.
.
,
a
n
a_1, a_2, ..., a_n
a1,a2,...,an,表示数组a中的整数。
【输出格式】
一行,一个正整数,表示a中整数全部变成0所需要的操作次数。
【样例输入 1】
3
2 3 4
【样例输出 1】
7
【样例输入 2】
5
1 3 2 2 5
【样例输出 2】
13
【数据范围】
对于所有测试点,保证
1
≤
n
≤
100
,
0
≤
a
i
≤
100
1 \le n \le 100, 0 \le a_i \le 100
1≤n≤100,0≤ai≤100 。
日历制作
【问题描述】
小 A 想制作 2025 年每个月的日历。他希望你能编写一个程序,按照格式输出给定月份的日历。
具体来说,第一行需要输出 MON TUE WED THU FRI SAT SUN ,分别表示星期一到星期日。接下来若干行中依次输出这个月所包含的日期,日期的个位需要和对应星期几的缩写最后一个字母对齐。例如,2025 年 9 月 1 日是星期一,在输出九月的日历时,1 号的个位 1 就需要与星期一 MON 的最后一个字母 N 对齐。九月的日历输出效果如下:
MON TUE WED THU FRI SAT SUN
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30
你能帮助小 A 完成日历的制作吗?
【输入格式】
一行,一个正整数m,表示需要按照格式输出 2025 年m月的日历。
【输出格式】
输出包含若干行,表示 2025 年m月的日历。
【样例输入 1】
9
【样例输出 1】
MON TUE WED THU FRI SAT SUN
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30
【样例输入 2】
6
【样例输出 2】
MON TUE WED THU FRI SAT SUN
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30
【数据范围】
对于所有测试点,保证
1
≤
m
≤
12
1 \le m \le 12
1≤m≤12。

4259

被折叠的 条评论
为什么被折叠?



