2024年3月GESP等级认证C++编程八级真题及答案

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

答案

D

C

B

A

C

D

D

A

D

B

C

A

C

B

C

第 题  为丰富⾷堂菜谱 ,炒菜部进⾏头脑风暴  ⾁类有鸡⾁ 、⽜⾁ 、⽺⾁ 、猪⾁4 ,切法有⾁排、 ⾁块、 ⾁末3      ,配菜有圆⽩菜、油菜、⾖腐3 ,辣度有⿇辣、微辣、不3 。不考虑⼝感的情况下 ,选1种⾁  1种切法、 1 配菜、 1种辣度产⽣⼀道菜(例如:⿇辣⽜⾁⽚炒⾖腐 这样能产⽣多少道菜   

A. 13

B. 42

C. 63

D. 108

第 题  已知袋中有2个相同的红球、3个相同的绿球、5个相同的黄球 。每次取出⼀个不放回 ,全部取出 。可能产⽣ 多少种序列   

A. 6

B. 1440

C. 2520

D. 3628800

第 题  以下⼆维数组的初始化 ,哪个是符合语法的   

  A.  int a[][] = {{1, 2}, {3, 4}};

  B.  int a[][2] = {};

  C.  int a[2][2] = {{1, 2, 3}, {4, 5, 6}};

  D.  int a[2][] = {{1, 2, 3}, {4, 5, 6}};

第  下⾯有关C++拷贝构造函数的说法 ,错误的是  

  A. 必须实现拷贝构造函数 ,否则⼀定会出现编译错误。

  B. 对象作为函数参数、 以值传递⽅式传⼊函数时 ,会⾃动调⽤拷贝构造函数。

  C. 对象作为函数返回值、 以值传递⽅式从函数返回时 ,会⾃动调⽤拷贝构造函数。

  D. 使⽤⼀个对象初始化另⼀个对象时 ,会⾃动调⽤拷贝构造函数。

第  使⽤邻接表表达⼀个⽆向简单图, 图中包含 v 个顶点、  e 条边 ,则该表中边节点的个数为  

 A. 0 × (      1 )

0 B0 × 0

  C. 2 × e

 D. e

第  关于⽣成树的说法 ,错误的是  

  A. ⼀个⽆向连通图可以有多个⽣成树。

 B. ⼀个⽆向图 ,只要连通 ,就⼀定有⽣成树。

  C.  n 个顶点的⽆向完全图 ,有棵⽣成树。

0 D.  n 个顶点的⽆向图 ,⽣成树包含 n-1 条边。

第 题  已知三个 double 类型的变量 a   b  theta 分别表⽰⼀个三角形的两条边长及⼆者的夹角(弧度  下列哪个表达式可以计算这个三角形的周长   

A.  a * b * s in(theta) / 2

B.  a + b + (a + b) * s in(theta) / 2

0 C.  a * b * cos(theta) / 2

D.   a + b + sqrt(a * a + b * b - 2 * a * b * cos(theta))

第  在有 n 个元素的⼆叉排序树中进⾏查找 ,其最好、最差时间复杂度分别为  

 A0) 0()

 B0(⑴ o(log n)

 C. o(log n) O(log n)

 D. 0(log n) 0()

第  如下图所⽰ ,半径为 r  圆⼼角为 t (弧度) 的扇形 ,下⾯哪个表达式能够求出顶部阴影部分的⾯积?  (

)  

A.  r * r * s in(t) / 2

B.  r * r * t / 2

0 C.  r * r * (t - s in(t))

0 D.  r * r * (t - s in(t)) / 2

第 10 题  下⾯程序的时间复杂度为  

1

2

3

4

5

int fib(int n) {

if (n <= 1)

return 1;

return fib(n 1) fib(n - 2);

}

 A. 0(2")

0 B.  其中 

 C. 0(n)

0 D. 0 )

第 11 题  下⾯程序的时间复杂度为  

1

2

3

4

5

int choose(int n, int m) {

if (m == 0 || m == n)

return 1;

return choose(n - 1m - 1) + choose(n - 1, m);

}

 A. 0(2")

 B0(2m × (n - m))

 C. 0(C(n, M))

 D. 0(m × (n - m))

第 12 题  下⾯程序的时间复杂度为  

1

2

3

4

5

6

7

8

9

10

11

12

13

int primes[MAXP], num = 0;

bool isPrime[MAXN] = {false};

void sieve() {

for (int n = 2; n <= MAXN; n++) {

if (!isPrime[n])

primes[num++= n;

for (int i 0; i < num && n * primes[i] <= MAXN; i++) {

isPrime[* primes[i]] = true;

if (% primes[i] == 0)

break;

}

}

}

0 A. 0()

 B0(n × logn)

 C. 0(n × 1oglog n)

0 D. 0(n2)

第 13 题  下⾯程序的输出为  

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

#include <iostream>

using namespace std;

int a[10][10];

int main() {

int m = 5, n = 4;

for (int x = 0; x <= m; x++)

a[x][0] = 1;

for (int y = 1; y <= n; y++)

a[0][y] = 1;

for (int x = 1; x <= m; x++)

for (int y = 1; y <= n; y++)

a[x][y= a[x - 1][y] + a[x][y - 1];

cout << a[m][n] << endl;

return 0;

}

A. 4

B. 5

C. 126

D. 3024

第 14 题  下⾯程序的输出为  

1

2

3

4

5

6

7

8

9

10

11

12

13

#include <iostream>

using namespace std;

int main() {

int cnt = 0;

for (int x = 0; x <= 10; x++)

for (int y = 0y <= 10; y++)

for (int = 0; z <= 10; z++)

if (x + y + z == 15)

cnt++;

cout << cnt << endl;

return 0;

}

A. 90

B. 91

O C. 96

第 15 题  下⾯的程序使⽤邻接矩阵表达的带权⽆向图 ,则从顶点0到顶点3的最短距离为  

1

2

3

4

5

int weight[4][4] {  0,   1,   {  1,   0,   {  7,   5,   {100,  15,

= {

7, 100},

5,  15},

0,   6},

6,   0}};

A. 100

B. 16

C. 12

D. 13

2      2

20 

    1    2    3    4    5    6    7    8    9    10

答案                           

第 题  已知 int 类型的变量 a  b ,则执⾏语句 a, b = b, a;  ,变量 a  b 的值会互换。

第  ⼀个袋⼦中有3个完全相同的红⾊⼩球、2个完全相同的蓝⾊⼩球 。每次从中取出1 ,再放回袋⼦ ,这样进 3次后 ,可能的颜⾊顺序有7种。

第  孙⼦定理是求解⼀次同余⽅程组的⽅法 ,最早见于中国南北朝时期(公元5世纪) 的数学著作《孙⼦算 经》 。⼜称中国余数定理 ,是中国数学史上的⼀项伟⼤成就。

第  个顶点的⽆向完全图有    条边。

第  为解决哈希函数冲突 ,在哈希表项内设置链表存储该项内的所有冲突元素 ,则该哈希表内查找元素的最差时 间复杂度为 

第  求⼀个包含 v 个顶点、  e 条边的带权连通⽆向图的最⼩⽣成树 Prim算法的时间复杂度为 

第 题  已知 int 类型的变量 a  b  c 中分别存储着⼀个三角形的三条边长 ,则这个三角形的⾯积可以通过表达  sqrt((a + b + c) * (b + c - a) * (a + c - b) * (a + b - c)) / 4 求得。

第  可以使⽤深度优先搜索算法判断图的连通性。

第  个元素的⼆叉排序树中查找⼀个元素 ,平均情况的时间复杂度是 

第 10  给定 double 类型的变量 x  ,且其值⼤于等于 我们可以通过⼆分法求出的近似值。

3      25  50 

3.1      1

  试题名称:公倍数问题

3.1.1     问题描述                                                                                                                                 

⼩ 写了⼀个 N X M 的矩阵 A ,我们看不到这个矩阵 ,但我们可以知道 ,其中第 i ⾏第列的元素 Ai,j 是 i  j 的 公倍数  。现在有 个⼩朋友 ,其中第 个⼩朋友想知道 ,矩阵 中最多有多少个元 素可以是 k  。请你帮助这些⼩朋友求解。

注意:每位⼩朋友的答案互不相关 ,例如 ,有些位置既可能是  ,⼜可能是  ,则它同可以时满⾜ c , y 两名⼩朋友的 要求。

⽅便起见 ,你只需要输出Kk=1 k × ank 即可 ,其中 ansk 表⽰第 k 名⼩朋友感兴趣的答案。

3.1.2     输入描述                                                                                                                               

第⼀⾏三个正整数N,M, K

3.1.3     输出描述                                                                                                                               

输出⼀⾏ 即 Kk=1 k ×  ansk 

请注意 ,这个数可能很⼤ ,使⽤ C++语⾔的选⼿请酌情使⽤  long long 等数据类型存储答案。

3.1.4     特别提醒                                                                                                                                 

在常规程序中 ,输⼊ 、输出时提供提⽰是好习惯 。但在本场考试中, 由于系统限定 ,请不要在输⼊ 、输出中附带任 何提⽰信息。

3.1.5     样例输入 1                                                                                                                                                       

3.1.6     样例输出 1

3.1.7     样例解释 1

只有 A , 可以是 ,其余都不⾏。

A1 A12  A2   A2,2  都可以是 2 ⽽其余不⾏

因此答案是 1  ×  1 + 2 × 4  9

3.1.8     样例输入 2

3.1.9     样例输出 2

3.1.10     数据规模

对于 30 的测试点 保证 NM, K  10

对于 60 的测试点 保证 NMK  500

对于 100 的测试点 保证 N, M  105 K

3.1.11     参考程序

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

#include <iostream>

#include <vector>

using namespace std;

vector<intcount_divisors(int limit, int num) {

vector<ints(num + 1, 0);

for (int i = 1; i <= limit; ++i) {

for (int j = i; j <= num; j += i) {

s[j] += 1;

}

}

return s;

}

int main() {

int N, M, K;

c in >> N >> M >> K;

vector<ints_N = count_divisors(N, 1000000);

vector<ints_M = count_divisors(M, 1000000);

long long result 0;

for (int = 1; k <= K; ++k) {

result += (long long)* s_N[k] * s_M[k];

}

cout << result << endl;

return 0;

}

3.2     编程题 2                                                                                                                                            

·   试题名称:接⽵竿

3.2.1     题面描述                                                                                                                                  

⼩杨同学想⽤卡牌玩⼀种叫做接⽵竿 的游戏。

游戏规则是:每张牌上有⼀个点数 v ,将给定的牌依次放⼊⼀列牌的末端 。若放⼊之前这列牌中已有与这张牌点数相 同的牌 ,则⼩杨同学会将这张牌和点数相同的牌之间的所有牌全部取出队列(包括这两张牌本⾝) 

⼩杨同学现在有⼀个长度为 n 的卡牌序列 A ,其中每张牌的点数为 Ai    1  。⼩杨同学有 次询问 。第    ( )  询问时 ,⼩杨同学会给出 li  ri ,⼩杨同学想知道如果⽤下标在 i  Ti的所有卡牌按照下标顺序玩接⽵  竿 的游戏 ,最后队列中剩余的牌数。

3.2.2     输入格式                                                                                                                                

第⼀⾏包含⼀个正整数 T ,表⽰测试数据组数。

对于每组测试数据 ,第⼀⾏包含⼀个正整数 ,表⽰卡牌序列 A 的长度。

第⼆⾏包含  个正整数 A ,A2 An ,表⽰卡牌的点数 A

第三⾏包含⼀个正整数  ,表⽰询问次数。

接下来  ,每⾏两个正整数 i  Ti ,表⽰⼀组询问。

3.2.3     输出格式

对于每组数据 ,输出  。第  输出⼀个⾮负整数 ,表⽰第 i 询问的答案。

3.2.4     样例 1

1

2

3

4

5

6

7

8

1

6

1 2 2 3 1 3

4

1 3

1 6

1 5

5 6

1

2

3

4

1

1

0

2

3.2.5     样例解释

对于第⼀次询问 ,⼩杨同学会按照 1 , 2  2  的顺序放置卡牌 ,在放置最后⼀张卡牌时 ,两张点数为 2  的卡牌会被收 ⾛, 因此最后队列中只剩余⼀张点数为 1  的卡牌。

对于第⼆次询问, 队列变化情况为:

{}  {1}  {1 , 2}  {1 , 2 , 2}  {1}  {1 , 3}  {1 , 3, 1}  {}  {3}  因此最后队列中只剩余⼀张点数为 3 的卡 牌。

3.2.6     数据范围

子任务编号   数据点占比    T                                     max Ai               特殊条件

1                        30            5

0           

13

2                     30             5  

1  5

104

  1 5 ×

104

13     所有询问的右端点等于 n

3                     40            5 

1 . 5

104

≤  1 . 5  ×

104

13

对于全部数据 保证有 1   T  5 1   n   1 . 5  ×  104   

3.2.7     参考程序

1

2

int nxt[N][30],pos[20];

int main(){

int t;

c in>>t;

while(t--){

int n;

c in>>n;

memset(pos,0,sizeof pos);

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

for(int i=1;i<=n;i++){

c in>>a[i];

for(int j=0;j<=20;j++)nxt[i][j]=n+1;

}

for(int i=n;i>=1;i--){

if(!pos[a[i]]){

nxt[a[i]][0]=n+1;

pos[a[i]]=i;

}else{

nxt[i][0]=pos[a[i]];

pos[a[i]]=i;

}

}

for(int i=n;i>=1;i--){

for(int j=1;j<=20;j++){

if(nxt[i][j-1]+1<=n)

nxt[i][j]=nxt[nxt[i][j-1]+1][j-1];

}

}

int q;

c in>>q;

while(q--){

int l,r;

c in>>l>>r;

int ii=l;

int ans=0;

while(ii<=r){

while(ii<=r&&nxt[ii][0]>r){

ii++;

ans++;

}

if(ii>r)break;

for(int j=20;j>=0;j--){

if(nxt[ii][j]<=r){

ii=nxt[ii][j];

break;

}

}

ii++;

}

cout<<ans<<"\n";

}

}

}

来源:6547题库网 http://www.6547.cn/doc/w4rnc2iitk

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/753299.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统——测试磁盘IOPS性能

目录 引言 一、IOPS指标受到的影响因素 二、提高IOPS性能的措施 三、测试IOPS性能命令 1.fio工具 2.ioping工具 引言 磁盘IOPS是指磁盘每秒钟可以完成的输入/输出操作数。它是衡量磁盘性能的一个重要指标&#xff0c;尤其对于需要处理大量随机读写操作的应用程序&…

B010-springcloud alibaba 分布式事务 Seata

目录 分布式事务基础事务本地事务分布式事务分布式事务的场景 分布式事务解决方案全局事务/两阶段提交可靠消息服务最大努力通知TCC事务 Seata介绍Seata实现分布式事务控制案例基本代码修改order微服务OrderSeataControllerOrderServiceImpl5注释容错相关代码ProductClient 修改…

C#语法基础

1. C#语言及其特点 C#是微软公司发布的一种面向对象、运行于.NET Framework和.NET Core&#xff08;完全开源&#xff0c;跨平台&#xff09;之上的最高级程序设计语言。C#是一种安全的、稳定的、简单的、优雅的&#xff0c;由C和C衍生出来的面向对象的程序语言。它在继承C和C…

IPSEC VPN-详解原理

目录 IPSEC提供的安全服务 IPSEC协议簇 ​编辑 安全协议 1.传输模式 2. 隧道模式 AH ---鉴别头协议 AH提供的安全服务&#xff1a; AH头部 AH的保护范围 1.传输模式 2.隧道模式 ​编辑 ESP ---封装安全载荷协议 ESP提供的安全服务&#xff1a; ESP的头部 ESP的保护范围 1.传输…

数据库国产化探究及升级改造过程指导

一、背景 在信创“自主可控”的浪潮下&#xff0c;政企行业首当其冲&#xff0c;基于国产化信创的要求&#xff0c;本部门某业务后端应用也需要针对分析开源组件的风险和开源协议的商业应用限制&#xff1b;能用国产化替代的评估后尽可替代割接&#xff0c;本期针对传统数据库…

22、设计模式之状态模式(State)

一、什么是状态模式 状态模式是一种行为型设计模式。它允许对象在内部状态发生改变时改变它的行为&#xff0c;简单地讲就是&#xff0c;一个拥有状态的context对象&#xff0c;在不同状态下&#xff0c;其行为会发生改变。 二、角色组成 上下文&#xff08;Context&#xff0…

n个猴子报数

n个猴子围坐一圈并按照顺时针方向从1到n编号&#xff0c;从第s个猴子开始进行1到m的报数&#xff0c;报数到第m的猴子退出报数&#xff0c;从紧挨它的下一个猴子重新开始1到m的报数&#xff0c;如此进行下去知道所有的猴子都退出为止。求给出这n个猴子的退出的顺序表。 输入输…

【Leetcode-54.螺旋矩阵】

题目&#xff1a; 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&#xff1a;[1,2,3,6,9,8,7,4,5]示例 2&#xff1a; 输入&#xff1…

从单机到分布式微服务,大文件校验上传的通用解决方案

一、先说结论 本文将结合我的工作实战经历&#xff0c;总结和提炼一种从单体架构到分布式微服务都适用的一种文件上传和校验的通用解决方案&#xff0c;形成一个完整的方法论。本文主要解决手段包括多线程、设计模式、分而治之、MapReduce等&#xff0c;虽然文中使用的编程语言…

外包干了3个月,技术明显进步。。。。。

在湖南的一个安静角落&#xff0c;我&#xff0c;一个普通的大专生&#xff0c;开始了我的软件测试之旅。四年的外包生涯&#xff0c;让我在舒适区里逐渐失去了锐气&#xff0c;技术停滞不前&#xff0c;仿佛被时间遗忘。然而&#xff0c;生活的转机总是在不经意间降临。 与女…

VMware安装Centos 7系统+设置共享文件夹+VMware Tools安装

文章目录 镜像下载地址下载页自己选择直接点击下边url下载 VMware环境1.新建虚拟机2.选择“自定义(高级)”&#xff0c;并点击【下一步】3.选择虚拟机硬件兼容性&#xff0c;并点击【下一步】4.选择“稍后安装操作系统”&#xff0c;并点击【下一步】5.选择操作系统版本&#x…

阿里云服务器地域怎么选?地域选择经验分享

阿里云服务器地域选择方法&#xff0c;如何选择速度更快、网络延迟更低的地域节点&#xff0c;地域指云服务器所在的地理位置区域&#xff0c;地域以城市划分&#xff0c;如北京、杭州、深圳及上海等&#xff0c;如何选择地域&#xff1f;建议根据用户所在地区就近选择地域&…

如何将大华dav视频转mp4?一键无损清晰转换~

Digital Audio Video&#xff08;DAV&#xff09;文件格式源于数字监控领域&#xff0c;旨在解决视频监控数据的存储和回放问题。随着数字监控技术的发展&#xff0c;DAV格式逐渐成为监控设备记录视频的标准格式&#xff0c;广泛应用于安防系统、摄像头监控等场景。 MP4文件格式…

掌握微服务性能监控:走向高效稳定的系统之路

掌握微服务性能监控&#xff1a;走向高效稳定的系统之路 一、微服务性能监控的挑战二、性能监控的目标与指标三、性能监控工具概览四、实践案例分析五、结语 大家好&#xff0c;这里是程序猿代码之路&#xff0c;在当今快速迭代和发布的软件开发周期中&#xff0c;微服务架构以…

付费代理IP与免费代理IP的区别

目录 一、稳定性与可用性 二、速度与性能 三、安全性与隐私保护 四、功能与服务 五、案例与代码示例 六、总结 在网络爬虫、数据分析、网络安全测试等场景中&#xff0c;代理IP的使用是非常普遍的。代理IP能够帮助用户隐藏真实IP地址&#xff0c;突破地域限制&#xff0c…

Linux系统下DNS配置指南

快速示例 在Linux系统中配置DNS&#xff0c;可以通过修改/etc/resolv.conf文件来设定首选DNS服务器&#xff1a;bash vim /etc/resolv.conf# 添加或修改以下内容 nameserver 114.114.114.114上述命令将系统DNS服务器设置为中国移动的公共DNS之一&#xff08;114.114.114.114&am…

6个选品建议,改善你的亚马逊现状。

一、市场热点与需求调研 深入研究当前市场趋势&#xff0c;了解消费者需求的变化。使用亚马逊的销售数据、评价、问答等功能&#xff0c;以及第三方市场研究工具&#xff0c;比如店雷达&#xff0c;分析潜在热销产品的特点。注意季节性需求&#xff0c;提前布局相关选品&#…

【数据挖掘】练习2:数据管理1

课后作业2&#xff1a;数据管理1 一&#xff1a;上机实验1 # 读入数据 data("CO2") # 查看数据集CO2中的变量名称&#xff0c;并将变量Treatment的名称更改为Treat names(CO2) names(CO2)[names(CO2) "Treatment"] <- "Treat" names(CO2)…

动态规划11 | ● *123.买卖股票的最佳时机III ● *188.买卖股票的最佳时机IV

*123.买卖股票的最佳时机III 考点 动态规划 我的思路 无思路 视频讲解关键点总结 关键点在于分为4个状态&#xff1a;第一次持有&#xff0c;第一次不持有&#xff0c;第二次持有&#xff0c;第二次不持有关键点2&#xff1a;最后直接返回最后一天的第二次不持有状态的dp值即可…

2024年金三银四Java面试常见50题

1、什么是Java&#xff1f; Java是一种跨平台的面向对象编程语言&#xff0c;最初由Sun Microsystems开发&#xff0c;现在由Oracle维护。 2、Java的特点是什么&#xff1f; 面向对象、跨平台、健壮性、安全性、简单性、可移植性、多线程、高性能。 3、Java的基本数据类型有…