CCF-GESP 等级考试 2023年9月认证C++四级真题

news2024/10/5 18:32:07

2023年9月

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

第 1 题 ⼈们所使⽤的⼿机上安装的App通常指的是( )。

  • A. ⼀款操作系统
  • B. ⼀款应⽤软件
  • C. ⼀种通话设备
  • D. 以上都不对

第 2 题 下列流程图的输出结果是?( )
在这里插入图片描述

  • A. 9
  • B. 7
  • C. 5
  • D. 11

第 3 题 对包含 n 个元素的数组进⾏冒泡排序,平均时间复杂度⼀般为( )。

  • A. O(n)
  • B. O(n log n)
  • C. O(n^2)
  • D. 以上都不正确

第 4 题 下列关于C++语⾔中指针的叙述,不正确的是( )。

  • A. 可以定义指向int 类型的指针。
  • B. 可以定义指向⾃定义结构体类型的指针。
  • C. ⾃定义结构体类型可以包含指针类型的元素。
  • D. 不能定义指向void类型的指针,那没有意义。

第 5 题 下列关于C++语⾔中数组的叙述,不正确的是( )。

  • A. ⼀维数组可以⽤来表⽰数列。
  • B. ⼆维数组可以⽤来表⽰矩阵。
  • C. 三维数组可以⽤来表⽰空间中物体的形状。
  • D. 世界是三维的,所以定义四维数组没有意义。

第 6 题 下列关于C++语⾔中函数的叙述,正确的是( )。

  • A. 函数调⽤前必须定义。
  • B. 函数调⽤时必须提供⾜够的实际参数。
  • C. 函数定义前必须声明。
  • D. 函数声明只能写在函数调⽤前。

第 7 题 下列关于C++语⾔中函数的叙述,不正确的是( )。

  • A. 两个函数的声明可以相同。
  • B. 两个函数的局部变量可以重名。
  • C. 两个函数的参数可以重名。
  • D. 两个函数可以重名。

第 8 题 ⼀个⼆维数组定义为char array[3][10]; ,则这个⼆维数组占⽤内存的⼤⼩为( )。

  • A. 10
  • B. 30
  • C. 32
  • D. 48

第 9 题 如果n 为int类型的变量,⼀个指针变量定义为int *p = &n;
,则下列说法正确的是( )。

  • A. 指针变量p的值与变量n是相同的。
  • B. 指针变量p的值与变量n的地址是相同的。
  • C. 指针变量p指向的值为’n’。
  • D. 指针变量p指向的值与变量n的地址是相同的。

第 10 题 ⼀个三维数组定义为long long array[6][6][6]; ,则array[1][2][3] 和array[3][2][1] 位置相差多少字节?( )

  • A. 70字节
  • B. 198字节
  • C. 560字节
  • D. ⽆法确定

第 11 题 如果a 为int类型的变量,且a的值为6,则执⾏a = ~a; 之后,a的值会是( )。

  • A. -6
  • B. 6
  • C. -7
  • D. 7

第 12 题 ⼀个数组定义为int a[5] = {1, 2, 3, 4, 5}; ,⼀个指针定义为int * p = &a[2]; ,则执⾏a[1]; 后,数组a中的值会变为( )。

  • A. {1, 2, 2, 4, 5}
  • B. {1, 3, 3, 4, 5}
  • C. {1, 2, 3, 3, 5}
  • D. {1, 2, 4, 4, 5}

第 13 题 下列关于C++语⾔中异常处理的叙述,正确的是( )。

  • A. ⼀个try ⼦句可以有多个catch ⼦句与之对应。
  • B. 如果try ⼦句在执⾏时发⽣异常,就⼀定会进⼊某⼀个catch ⼦句执⾏。
  • C. 如果try ⼦句中没有可能发⽣异常的语句,会产⽣编译错误。
  • D. catch ⼦句处理异常后,会重新执⾏与之对应的try ⼦句。

第 14 题 执⾏以下C++语⾔程序后,输出结果是( )。

#include <iostream>
using namespace std;
int main(){
int fib[10];
fib[0] = 0;
fib[1] = 1;
for(int i = 2; i < 10; i++)
	fib[i] = fib[i - 1] + fib[i - 2];
cout << fib[10] << endl;
return 0;
  • A. 0
  • B. 5
  • C. 55
  • D. ⽆法确定。

第 15 题 在下列代码的横线处填写( ),完成对有n 个int类型元素的数组array 由⼩到⼤排序。

void BubbleSort(int array[], int n){
	for(int i = n; i >= 2; i--)
		for(_________)//在此处填入代码
		if(array[j] > array[j + 1]){
		int t = array[j];
		array[j] = array[j + 1];
		array[j + 1] = t;
		}
}
  • A. int j = 1; j < n; j++
  • B. int j = 0; j < n; j++
  • C. int j = 0; j < i - 1; j++
  • D. int j = 0; j < i; j++

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

第 1 题 在C++语⾔中,指针变量在逻辑上指向另⼀个变量在内存中的位置,指针变量本⾝不占⽤内存。( )

第 2 题 对 (n) 个元素的数组执⾏插⼊排序算法,通常的时间复杂度是 (O(n^2))。( )

第 3 题 在C++语⾔中,每个变量都有其作⽤域。( )

第 4 题 在C++语⾔中,在函数调⽤时,通过引⽤传递的参数不会复制实际参数,因此不会额外占⽤内存。( )

第 5 题 在C++语⾔中,可以通过定义结构体,定义⼀个新的数据类型。( )

第 6 题 在C++语⾔中,可以定义结构体类型的数组变量,定义结构体时也可以包含数组成员。( )

第 7 题 如果希望记录10个最长为99字节的字符串,可以将字符串数组定义为 char s[10][100];。( )

第 8 题 ⼀个可能抛出异常的函数,调⽤它的位置没有在 try ⼦句中,会引起编译错误。( )

第 9 题 ==:= 都是C++语⾔的运算符。( )

第 10 题 通过使⽤⽂件重定向操作,可以将程序中输出到 cout 的内容输出到⽂件中,这是常⽤的记录程序运⾏⽇志的⽅法之⼀。( )

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

3.1 编程题 1

3.1.1 问题描述

N进制数指的是逢N进⼀的计数制。例如,⼈们⽇常⽣活中⼤多使⽤⼗进制计数,⽽计算机底层则⼀般使⽤⼆进制。除此之外,⼋进制和⼗六进制在⼀些场合也是常⽤的计数制(⼗六进制中,⼀般使⽤字母 A ⾄ F 表⽰⼗⾄⼗五;本题中,⼗⼀进制到⼗五进制也是类似的)。

在本题中,我们将给出N个不同进制的数。你需要分别把它们转换成⼗进制数。

3.1.2 提示

对于任意⼀个L位K进制数,假设其最右边的数位为第0位,最左边的数位为第L-1 位,我们只需要将其第 i 位的数码乘以权值 ( K^i ),再将每位的结果相加,即可得到原K进制数对应的⼗进制数。下⾯是两个例⼦:

  1. ⼋进制数 1362 对应的⼗进制数为 1 * (8^3) + 3 * (8 ^ 2) + 6 * (8^1) + 2 * (8 ^ 0) = 754;
  2. ⼗六进制数 3F0 对应的⼗进制数为 3 * (16^2) + 15 * (16^1) + 0 * (16 ^ 0) = 1008。
3.1.3 输入描述

输⼊的第⼀⾏为⼀个⼗进制表⽰的整数 N。接下来 N⾏,每⾏⼀个整数K,随后是⼀个空格,紧接着是⼀个K进制数,表⽰需要转换的数。保证所有K 进制数均由数字和⼤写字母组成,且不以 0 开头。保证K进制数合法。保证N ≤ 1000; 保证 2 ≤ K ≤16;
保证所有K进制数的位数不超过9。

3.1.4 输出描述

输出N⾏,每⼀个⼗进制数,表⽰对应K进制数的⼗进制数值。

3.1.5 样例输入 1
2
8 1362
16 3F0
3.1.6 样例输出 1
754
1008
3.1.7 样例输入 2
2
2 11011
10 123456789
3.1.8 样例输出 2
27
123456789

3.2 编程题 2

3.2.1 问题描述

⼩明刚刚学习了三种整数编码⽅式:原码、反码、补码,并了解到计算机存储整数通常使⽤补码。但他总是觉得⽣活中很少⽤到(2^31) - 1这么⼤的数,⽣活中常⽤的0 - 100这种数也同样需要⽤4个字节的补码表⽰,太浪费了些。

热爱学习的⼩明通过搜索,发现了⼀种正整数的变长编码⽅式。这种编码⽅式的规则如下:

  1. 对于给定的正整数,⾸先将其表达为⼆进制形式。例如,(0){10} = (0){2},(926){10} = (1110011110){2}。
  2. 将⼆进制数从低位到⾼位切分成每组 7 bit,不⾜ 7 bit 的在⾼位⽤ 0 填补。例如,(0){2}变为0000000 的⼀组,(1110011110){2}变为0011110和 0000111的两组。
  3. 由代表低位的组开始,为其加⼊最⾼位。如果这组是最后⼀组,则在最⾼位填上 0,否则在最⾼位填上 1。于是,0的变长编码为00000000一个字节,926的变长编码为 10011110 和 00000111两个字节。

这种编码⽅式可以⽤更少的字节表达⽐较⼩的数,也可以⽤很多的字节表达⾮常⼤的数。例如,987654321012345678 的⼆进制为(0001101 1011010 0110110 1001011 1110100 0100110 1001000 0010110 1001110){2},于是它的变长编码为(⼗六进制表⽰)CE 96 C8 A6 F4 CB B6 DA 0D,共 9 个字节。

你能通过编写程序,找到⼀个正整数的变长编码吗?

3.2.2 输入描述

输⼊第⼀⾏,包含⼀个正整数N。约定 0 ≤ N ≤ (10 ^ 18)

3.2.3 输出描述

输出⼀⾏,输出N对应的变长编码的每个字节,每个字节均以 2 位⼗六进制表⽰(其中 A-F 使⽤⼤写字母表⽰),两个字节间以空格分隔。

3.2.4 样例输入 1
0
3.2.5 样例输出 1
00
3.2.6 样例输入 2
926
3.2.7 样例输出 2
9E 07
3.2.8 样例输入 3
987654321012345678
3.2.9 样例输出 3
CE 96 C8 A6 F4 CB B6 DA 0D

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

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

相关文章

2024/5/22 学习杂记

为什么功率放大电路在模电中经常提到&#xff1f; 模拟信号&#xff1a;它是连续变化的电信号&#xff0c;它在时间上和幅度上都是连续的&#xff0c;能够代表信息的连续变化。大多数物理量为模拟信号&#xff0c;如&#xff1a;温度、压力、流量… 非电物理量通过传感器变换成…

RabbitMQ 消息队列安装及入门

市面常见消息队列中间件对比 技术名称吞吐量 /IO/并发时效性&#xff08;类似延迟&#xff09;消息到达时间可用性可靠性优势应用场景activemq万级高高高简单易学中小型企业、项目rabbitmq万级极高&#xff08;微秒&#xff09;高极高生态好&#xff08;基本什么语言都支持&am…

告别付费!这款开源软件让你免费看高清电视直播!

文章目录 📖 介绍 📖🏡 演示环境 🏡📝 开源详情 📝🎯 软件介绍🚀 软件特点🎈 获取方式 🎈⚓️ 相关链接 ⚓️📖 介绍 📖 🔮 揭秘一款神奇的软件,让你轻松畅游电视直播的海洋,无需付费,无需繁琐设置,即可畅享海量高清节目!想要知道它是什么吗?跟…

如何改变echo在Linux下的输出颜色

文章目录 问题回答常规输出字体加粗斜体字带下划线闪烁效果 参考 问题 我正在尝试使用 echo 命令在终端中打印文本。 我想把文本打印成红色。我该怎么做&#xff1f; 回答 你可以使用 ANSI escape codes 定义控制输出颜色的变量。 ANSI escape codes是一种用于在文本中设置…

Gitee在已有项目基础上创建仓库中遇到的问题和解决

问题一&#xff1a;fatal: remote origin already exists 解释&#xff1a;当前仓库添加了一个名为"origin"的远程仓库配置&#xff0c;此时输入 git remote add origin https://xxx就会提示上面的内容。 解决方案1:移除旧的origin git remote remove origin 解决方案…

pyqt6入门案例

效果预览 hello.ui <?xml version"1.0" encoding"UTF-8"?> <ui version"4.0"><class>Dialog</class><widget class"QDialog" name"Dialog"><property name"geometry"><…

2024年5月份最新独角数卡使用USDT详细小白教程

直观配套视频教程 2024年5月份最新独角数卡安装及USDT使用详细小白教程 1、创建服务器 Centos或者Ubuntu2、宝塔面板开心版安装寶塔 Linux 面版 8.0.5 開心版 - 2024年1月12日 - 开心专区 - 异次元 - Powered by Discuz!Centos安装命令&#xff08;默认安装是 8.0.1 直接在线升…

PyMySQL:连接Python与MySQL的桥梁

系列文章目录 更新ing... MySQL操作全攻略&#xff1a;库、表、数据、事务全面指南深入探索MySQL SELECT查询&#xff1a;从基础到高级&#xff0c;解锁数据宝藏的密钥MySQL SELECT查询实战&#xff1a;练习题精选&#xff0c;提升你的数据库查询技能PyMySQL&#xff1a;连接P…

代码随想录算法训练营第三十四天 | 理论基础、455.分发饼干、376、摆动序列、53.最大子序和

目录 理论基础 455.分发饼干 思路 代码 376.摆动序列 思路 代码 53.最大子序和 思路 代码 理论基础 代码随想录 455.分发饼干 代码随想录 思路 可以是大饼干优先满足大胃口&#xff0c;也可以是小饼干优先满足小胃口。 代码 class Solution:def findContentChildre…

【深度学习】与【PyTorch实战】

目录 一、深度学习基础 1.1 神经网络简介 1.2 激活函数 1.3 损失函数 1.4 优化算法 二、PyTorch基础 2.1 PyTorch简介 2.2 张量操作 2.3 构建神经网络 2.4训练模型 2.5 模型评估 三、PyTorch实战 3.1 数据加载与预处理 3.2 模型定义与训练 3.3 模型评估与调优 3…

与WAF的“相爱相杀”的RASP

用什么来保护Web应用的安全&#xff1f; 猜想大部分安全从业者都会回答&#xff1a;“WAF&#xff08;Web Application Firewall,应用程序防火墙&#xff09;。”不过RASP&#xff08;Runtime Application Self-Protection&#xff0c;应用运行时自我保护&#xff09;横空出世…

java操作Redis缓存设置过期时间

如何用java操作Redis缓存设置过期时间&#xff1f;很多新手对此不是很清楚&#xff0c;为了帮助大家解决这个难题&#xff0c;下面小编将为大家详细讲解&#xff0c;有这方面需求的人可以来学习下&#xff0c;希望你能有所收获。 在应用中我们会需要使用redis设置过期时间&…

android studio接入facebook踩坑1

今天在接入facebook第三方登录的时候&#xff0c;点击登录按钮&#xff0c;APP闪退&#xff0c;并报错 java.lang.RuntimeException Failure delivering result ResultInfo{whonull,request64206,result-1} 新文章链接https://lengmo714.top/facebook1.html 如下图&#xff1a;…

网络传输层

叠甲&#xff1a;以下文章主要是依靠我的实际编码学习中总结出来的经验之谈&#xff0c;求逻辑自洽&#xff0c;不能百分百保证正确&#xff0c;有错误、未定义、不合适的内容请尽情指出&#xff01; 文章目录 1.端口号的基础2.传输层两协议2.1.UDP 协议2.1.1.协议结构2.1.2.封…

【Redis7】Redis持久化机制之RDB

文章目录 1.RDB简介2.RDB配置触发设置3.RDB的优缺点4.如何检查修复RDB文件5.如何禁用RDB6.RDB参数优化7.总结 1.RDB简介 Redis持久化机制中的RDB&#xff08;Redis Database&#xff09;是一种将Redis在某个时间点的数据以快照形式保存到磁盘上的方法。 原理&#xff1a;RDB通…

期货交易的雷区

一、做自己看不懂的行情做交易计划一样要做有把握的&#xff0c;倘若你在盘中找机会交易&#xff0c;做自己看不懂的行情&#xff0c;即便你做进去了&#xff0c;建仓时也不会那么肯定&#xff0c;自然而然持仓也不自信&#xff0c;有点盈利就想平仓&#xff0c;亏损又想扛单。…

Go 和 Delphi 定义可变参数函数的对比

使用可变参数函数具有灵活性、重用性、简化调用等优点&#xff0c;各个语言有各自定义可变参数函数的方法&#xff0c;也有通用的处理方法&#xff0c;比如使用数组、定义参数结构体、使用泛型等。 这里总结记录一下 go、delphi 的常用的定义可变参数函数的方式&#xff01; 一…

句柄降权绕过CallBacks检查

看到前辈们相关的文章&#xff0c;不太明白什么是句柄降权&#xff0c;于是专门去学习一下&#xff0c;过程有一点波折。 句柄降权 什么是句柄 当一个进程利用名称来创建或打开一个对象时&#xff0c;将获得一个句柄&#xff0c;该句柄指向所创建或打开的对象。以后&#xf…

前端自动将 HTTP 请求升级为 HTTPS 请求

前端将HTTP请求升级为HTTPS请求有两种方式&#xff1a; 一、index.html 中插入meta 直接在首页 index.html 的 head 中加入一条 meta 即可&#xff0c;如下所示&#xff1a; <meta http-equiv"Content-Security-Policy" content"upgrade-insecure-requests&…

metaMIC:无参考错误组装识别和校正宏基因组组装

#环境很重要&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; conda create -n metaMIC conda activate metaMIC mamba install python3.8 mamba install -c …