2024年06月CCF-GESP编程能力等级认证C++编程四级真题解析

本文收录于专栏《C++等级认证CCF-GESP真题解析》,专栏总目录:点这里。订阅后可阅读专栏内所有文章。

一、单选题(每题 2 分,共 30 分)

第 1 题

下列代码中,输出结果是( )
在这里插入图片描述

A. 12 24 24 12
B. 24 12 12 24
C. 12 12 24 24
D. 24 24 12 12

答案:B

第 2 题

下面函数不能正常执行的是()
A.
在这里插入图片描述

B.
在这里插入图片描述

C.
在这里插入图片描述

D.
在这里插入图片描述

答案:B

第 3 题

下面程序输出的是()
在这里插入图片描述

A. 2 2 3 9
B. 2 10 3 9
C. 2 10 11 121
D. 2 10 3 100

答案:B

第 4 题

假设变量 a 的地址是0x6ffe14,下面程序的输出是( )。
在这里插入图片描述

A. 10
B. 0x6ffe14
C. 0x6ffe15
D. 0x6ffe18

答案:D

第 5 题

如果下列程序输出的地址是 0x6ffe00 ,则 cout<<a+1<<endl; 输出的是()
在这里插入图片描述

A. 0x6ffe04
B. 0x6ffe0C
C. 0x6ffe08
D. 0x6ffe00

答案:B

第 6 题

C++中,关于文件路径说法错误的是()
A. “GESP.txt”:指定与当前工作目录中的程序文件相同目录中的 GESP.txt 文件
B. “…/data/GESP.txt”:指定与当前工作目录中的程序文件上一级目录下的 data 目录中的 GESP.txt 文件
C. “./data/GESP.txt”:指定与当前工作目录中的程序文件同级目录下的 data 目录中的 GESP.txt 文件
D. "GESP.txt"是绝对路径

答案:D

第 7 题

关于直接插入排序,下列说法错误的是()
A. 插入排序的最好情况是数组已经有序,此时只需要进行 次比较,时间复杂度为
B. 最坏情况是数组逆序排序,此时需要进行 次比较以及 次赋值操作(插入)
C. 平均来说插入排序算法的复杂度为
D. 空间复杂度上,直接插入法是就地排序,空间复杂度为

答案:D

第 8 题

下列程序横线处,应该输入的是 ( )。
在这里插入图片描述

A. swap(a[j],a[j+1]);
B. swap(a[j-1],a[j]);
C. swap(a[j-1],a[j+1]);
D. swap(&a[j-1],&a[j+1]);

答案:A

第 9 题

下面关于递推的说法不正确的是( )。
A. 递推表现为自己调用自己
B. 递推是从简单问题出发,一步步的向前发展,最终求得问题。是正向的
C. 递推中,问题的n要求是在计算中确定,不要求计算前就知道n
D. 斐波那契数列可以用递推实现求解

答案:A

第 10 题

关于几种排序算法的说法,下面说法错误的是( )。
A. 选择排序不是一个稳定的排序算法
B. 冒泡排序算法不是一种稳定的排序算法
C. `插入排序是一种稳定的排序算法
D. 如果排序前2个相等的数在序列中的前后位置顺序和排序后它们2个的前后位置顺序相同,则称为一种稳定的排序算法

答案:B

第 11 题

数组{45,66,23,1,10,97,52,88,5,33}进行从小到大冒泡排序过程中,第一遍冒泡过后的序列是( )。
A. {45,23,1,10,66,52,88,5,33,97}
B. {45,66,1,23,10,97,52,88,5,33}
C. {45,66,23,1,10,52,88,5,33,97}
D. {45,66,23,1,10,97,52,88,33,5}

答案:A

第 12 题

下面的排序算法程序中,横线处应该填入的是( )。

int a[8]={ 2,3, 4, 5, 6,2,3,1};
for (int i=1;i<8;i++)
{
	int key = a[i];
	int j=i-1;
	while(a[j]>key && j>=0)
	{
		________;
		j -= 1;
	}
	a[j + 1]= key;
}

A. a[j]=a[j-1];
B. a[j]=a[j+1];
C. a[j+1]=a[j-1];
D. a[j+1]=a[j];

答案:D

第 13 题

下面的程序中,如果输入 10 0 ,会输出( )。
在这里插入图片描述

A. Division by zero condition!
B. 0
C. 10
D. 100

答案:A

第 14 题

10条直线,最多可以把平面分为多少个区域( )。
A. 55
B. 56
C. 54
D. 58

答案:B

第 15 题

下面程序中,如果语句 cout<<p<<endl; 输出的是 0x6ffe00 ,则 cout<<++p<<endl; 输出的是()

int x[10][10][10]={{0}};
int *p;
p=&x[0][0][0];
cout<<p<<endl;
cout<<++p<<endl;

A. 0x6ffe0c
B. 0x6ffe09
C. 0x6ffe06
D. 0x6ffe04

答案:D

二、判断题(每题 2 分,共 20 分)

第 16 题

int& a 和 &a 是一样的,都是取 a 的地址。

答案:错误

第 17 题

以下代码不能够正确执行。
在这里插入图片描述

答案:正确

第 18 题

引用是一个指针常量。

答案:正确

第 19 题

下面程序两个输出结果是一样的。
在这里插入图片描述

答案:正确

第 20 题

函数不可以调用自己。

答案:错误

第 21 题

函数参数传递过程中,如果传常量值、常量引用和常量指针都是不能被修改的,它们可以防止函数对实参的值或地址进行修改。

答案:正确

第 22 题

下面代码输出的值等于0。
在这里插入图片描述

答案:正确

第 23 题

在下面这个程序里, a[i][j] 和一个普通的整型变量一样使用。
在这里插入图片描述

答案:正确

第 24 题

一个一维数组,至少含有一个自然数N,是一个合法的数列。可以在一维数组末尾加入一个自然数M,M不能超过一维数组末尾元素的一半,形成一个新的合法的一维数组,如果N=6,那么可以有6个不同的合法数组。

答案:正确

第 25 题

插入排序算法中,平均时间复杂度是 ,最坏的情况逆序情况下,达到最大时间复杂度。

答案:正确

三、编程题(每题 25 分,共 50 分)

第 26 题

试题名称:黑白方块
时间限制:1.0 s
内存限制:512.0 MB
题面描述
小杨有一个 n n n m m m 列的网格图,其中每个格子要么是白色,要么是黑色。
对于网格图中的一个子矩形,小杨认为它是平衡的当且仅当其中黑色格子与白色格子数量相同。
小杨想知道最大的平衡子矩形包含了多少个格子。
输入格式
第一行包含两个正整数 n , m n,m n,m,含义如题面所示。
之后 n n n 行,每行一个长度为 m m m 01 01 01 串,代表网格图第 i i i 行格子的颜色,如果为 0 0 0,则对应格子为白色,否则为黑色。
输出格式
输出一个整数,代表最大的平衡子矩形包含格子的数量,如果不存在则输出 0 0 0
样例1

4 5
00000
01111
00011
00011
16

样例解释
对于样例1,假设 ( i , j ) (i,j) (i,j) 代表第 i i i 行第 j j j 列,最大的平衡子矩形的四个顶点分别为 ( 1 , 2 ) (1,2) (1,2) ( 1 , 5 ) (1,5) (1,5) ( 4 , 2 ) (4,2) (4,2) ( 4 , 5 ) (4,5) (4,5)
数据范围
对于全部数据,保证有 1 ≤ n , m ≤ 10 1≤n,m≤10 1n,m10
参考程序

#include<bits/stdc++.h>
using namespace std;
const int N = 55;
int w[N][N];
int n,m;
bool check(int xa,int ya,int xb,int yb){
	int a[2]={0,0};
	for(int i = xa;i<=xb;i++){
		for(int j=ya;j<=yb;j++){
			a[w[i][j]]++;
		}
	}
	
	return a[0]==a[1];
}
int main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		string s;
		cin>>s;
		for(int j=1;j<=m;j++){
			w[i][j]=s[j-1]-'0';
		}
	}
	int ans = 0;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			for(int ii=i;ii<=n;ii++){
				for(int jj=j;jj<=m;jj++){
					if(check(i,j,ii,jj)){
						ans = max(ans,(ii-i+1)*(jj-j+1));
					}
				}
			}
		}
	}
	cout<<ans<<"\n";
}

第 27 题

试题名称:宝箱
时间限制:1.0 s
内存限制:512.0 MB
题面描述
小杨发现了 n n n 个宝箱,其中第 i i i 个宝箱的价值是 a i a_i ai
小杨可以选择一些宝箱放入背包并带走,但是小杨的背包比较特殊,假设小杨选择的宝箱中最大价值为 x x x,最小价值为 y y y,小杨需要保证 x − y ≤ k x-y≤k xyk,否则小杨的背包会损坏。
小杨想知道背包不损坏的情况下,自己能够带走宝箱的总价值最大是多少。
输入格式
第一行包含两个正整数 n , k n,k n,k,含义如题面所示。
第二行包含 n n n 个正整数 a 1 , a 2 , . . . , a n a_1,a_2,...,a_n a1,a2,...,an,代表宝箱的价值。
输出格式
输出一个整数,代表带走宝箱的最大总价值。
样例1

5 1
1 2 3 1 2
7

样例解释
在背包不损坏的情况下,小杨可以拿走两个价值为 2 2 2 的宝箱和一个价值为 3 3 3 的宝箱。
数据范围
对于全部数据,保证有 1 ≤ n ≤ 1000 , 0 ≤ k ≤ 1000 , 1 ≤ a i ≤ 1000 1≤n≤1000,0≤k≤1000,1≤a_i≤1000 1n1000,0k1000,1ai1000
参考程序

#include<bits/stdc++.h>
using namespace std;
const int N = 1010;
int a[N];
int n,k;
int main(){
	cin>>n>>k;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	sort(a+1,a+n+1);
	int ans=0;
	for(int i=1;i<=n;i++){
		int sum=0;
		for(int j=i;j>=1;j--){
			if(a[i]-a[j]<=k){
				sum+=a[j];
			}else break;
		}
		ans=max(ans,sum);
	}
	cout<<ans<<"\n";
}

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 03:28:04       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 03:28:04       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 03:28:04       58 阅读
  4. Python语言-面向对象

    2024-07-15 03:28:04       69 阅读

热门阅读

  1. Yolo系列合集

    2024-07-15 03:28:04       21 阅读
  2. 如何打开SQLServer配置管理器

    2024-07-15 03:28:04       20 阅读
  3. SQL笔试题【数据岗】

    2024-07-15 03:28:04       20 阅读
  4. sqlalchemy排序

    2024-07-15 03:28:04       18 阅读
  5. 深入探讨微服务架构设计模式与常见实践

    2024-07-15 03:28:04       19 阅读
  6. SQL执行慢的原因?如何排查?

    2024-07-15 03:28:04       23 阅读
  7. 常用设计模式

    2024-07-15 03:28:04       22 阅读
  8. Mybatis 传递数组给sql解析 解决not in失效问题

    2024-07-15 03:28:04       20 阅读