【C++】笔试训练(九)
目录
- 一、选择题
- 二、编程题
- 1、另类加法
- 2、走方格的方案数
一、选择题
1、某函数申明如下
void Func(int& nVal1);
有int a,下面使用正确的为()
A Func(a)
B Func(&a)
C Func(*a)
D Func(&(*a))
答案:A
2、C++语言中,类ClassA的构造函数和析构函数的执行次数分别为()
ClassA* pclassa = new ClassA[5];
delete pclassa;
A 5,1
B 1,1
C 5,5
D 1,5
答案:A
解析:
1.malloc/calloc/realloc---->free
2.new ----> detele
3.new[] ----> detele
这三种申请空间的方式一定要匹配使用,否则程序可能会产生内存泄露,或者程序可能会崩溃
new T
1.调用operator new(size) 申请空间 ----> 内部是调用malloc循环申请
2.调用T的构造函数对申请的空间进行初始化
delete P
1.调用析构函数释放p指向对象中的资源
2.调用operator delete释放p所指向的空间 ----> 内部真正释放空间的是调用free
注意:new只能申请单个元素的空间,delete只能释放单个元素的空间
new T[N]
1.调用operator new申请空间 ----> 也是调用operator new(size) 申请空间
2.调用N次T的构造函数
delete[] P
1.调用N次析构函数释放p指向的N个对象
2.调用operator delete释放空间 ----> 也是调用operator delete§
题目中使用delete pclassa;释放空间,只释放了p指向的空间中的一个对象,是不严谨的,运行中可能会产生程序崩溃
3、 动态内存分配(C语言中malloc,C++中的new)得到的存储区属于内存中的:
A 静态区
B 堆(heap)
C 栈(stack)
D 堆栈
E 内核内存
F 不确定
答案:B
4、下列静态数据成员的特性中,错误的是()
A 引用静态数据成员时,要在静态数据成员名前加<类名>和作用域符号
B 说明静态数据成员时前边要加关键字static来修饰
C 静态数据成员在类体外进行初始化
D 静态数据成员不是所有对象所共有的
答案:D
解析:
静态数据成员(静态成员变量):所有对象共享的,并不属于具体的某个对象----在类中声明,然后需要在类外单独进行定义,一定不能在构造函数的初始化列表的位置初始化----在类外访问静态成员变量时:对象.静态成员变量 或者 类名::静态成员变量
5、用class关键字定义的类,其成员默认的访问属性为()
A private
B protected
C public
D 无定义
答案:A
6、在重载一个运算符为成员函数时,其参数表中没有任何参数,这说明该运算符是 ( )
A 无操作数的运算符
B 二元运算符
C 前缀一元运算符
D 后缀一元运算符
答案:C
解析:
一元运算符:指的是该元素只需要一个参数,比如:++、- -
成员函数:每个非静态的成员函数都有一个隐藏的this指针
比如:Dete& operator++() 前置++
Date operator++(int) 后置++
7、有如下程序:
#include<iostream>
using namespace std;
class MyClass {
public:MyClass(int i = 0) { cout << 1; }MyClass(const MyClass& x) { cout << 2; }MyClass& operator=(const MyClass& x) { cout << 3; return*this; }~MyClass() { cout << 4; }
};
int main() {MyClass obj1(1), obj2(2), obj3(obj1);return 0;
}
运行时的输出结果是
A 121,444
B 112,444
C 11,114,444
D 11,314,445
E 11,314,444
答案:B
8、下面有关c++静态数据成员,说法正确的是()
A 不能在类内初始化
B 不能被类的对象调用
C 不能受private修饰符的作用
D 可以直接用类名调用
答案:D
解析:
静态数据成员(静态成员变量):所有对象共享的,并不属于具体的某个对象----在类中声明,然后需要在类外单独进行定义,一定不能在构造函数的初始化列表的位置初始化----在类外访问静态成员变量时:对象.静态成员变量 或者 类名::静态成员变量
有个特殊:const修饰的,可以在类内初始化
class A
{
private:
const static int a = 10;
static int b;
};
int A::b = 20;
9、在C++中,为了让某个类只能通过new来创建(即如果直接创建对象,编译器将报错),应该()
A 将构造函数设为私有
B 将析构函数设为私有
C 将构造函数和析构函数均设为私有
D 没有办法能做到
答案:B
解析:
A类:假设A类的构造函数是私有的
在类外:A* pa = new A[];这是错误的
new原理:1.申请空间
2.调用构造函数对申请的空间进行初始化
假设A类的构造函数是私有的,就不能在构造函数对申请的空间进行初始化,第二步就不能完成了
创建对象期间,只需要申请空间,operator new这个函数就已经处理了。
delete pa;
delete原理:1.调用A类的析构函数
2.释放空间
把析构函数设成私有的,第一步就不能完成了,但是,我们可以给A类增加一个公有的方法:void Release(A*& p) { delete p; }
10、下列的模板声明中,其中几个是正确的()
1)template
2)template<T1,T2>
3)template<class T1,T2>
4)template<class T1,class T2>
5)template<typename T1,T2>
6)template<typename T1,typename T2>
7)template<class T1,typename T2>
8)<typename T1,class T2>
A 2
B 3
C 4
D 5
答案:B
解析:template< class T >、template< typename T >、template< class T1, class T2 >这三种是正确的
其中4、6、7是正确的
二、编程题
1、另类加法
入口:题目链接
题目描述:
题目解析:
本题的意思是自己实现加法,不用现成的运算符
解题思路:
本题可以通过位运算实现,具体实现:两个数求和,其实就是求和后当前位的数据+两个数求和的进位
例如:
1 + 2: 00000001 + 00000010
求和后当前位的数据: 00000011 ; 求和后的进位数据: 没有进位,则 00000000
两者相加,则得到: 00000011 就是3
2 + 2: 00000010 + 00000010
求和后当前位的数据: 00000000, 1和1进位后当前为变成0了
求和后进位的数据: 00000100, 两个1求和后进位了
相加后得到: 00000100 就是4
求和后当前位的数据:简便的计算方法就是两个数进行异或 00000001 ^ 00000010 -> 00000011
求和后进位的数据:简便的计算方法就是两个数相与后左移一位 (00000010 & 00000010) << 1
所以这道题使用递归更加容易理解
代码展示:
class UnusualAdd {
public:int addAB(int A, int B) {if (B == 0)return A;if (A == 0)return B;int a = A ^ B;//求和后当前位的数据int b = (A & B) << 1;//求和后进位的数据return addAB(a, b);//递归两个数进行相加,任意为0时截止}
};
2、走方格的方案数
入口:题目链接
题目描述:
题目解析:
本题为求取路径总数的题目,一般可以通过递归求解,对于复杂的问题,可以通过动态规划求解。
解题思路:
| 1 | 2 | 3 |
| 4 | 5 | 6 |
| 7 | 8 | 9 |
对于上面的n * m(3 * 3)的格子,有两种情况
a. 如果n或者m为1,则只有一行或者一列,从左上角走到右下角的路径数为n + m
比如: 1 * 1格子,可以先向下走,再向右走,到达右下角;或者先向右走,再向下走,到达右下角,共两条,即 1 + 1 = 2,对于1 * m和 n * m的情况同学们自己画一下
b. 如果n,m都大于1,那么走到[n][m]格子的右下角只有两条路径,
<1>: 从[n - 1][m]格子的右下角向下走,到达
<2>: 从[n][m - 1]格子的右下角向右走,到达
所以走到[n][m]格子的右下角的数量为[n-1][m] + [n][m - 1],可以通过递归实现,情况a为递归的终止条件
递归代码展示:
#include <iostream>
using namespace std;
int pathnum(int n, int m)
{if (n == 0 || m == 0){return 1;}return pathnum(n - 1, m) + pathnum(n, m - 1);
}int main()
{int n, m;while (cin >> n >> m){cout << pathnum(n, m) << endl;}
}
动态规划代码展示:
#include <iostream>
#include <vector>
using namespace std;
int pathnum(int n, int m)
{vector<vector<int>> dp(n + 1, vector<int>(m + 1, 1));for (int i = 1; i <= n; i++){for (int j = 1; j <= m; j++){dp[i][j] = dp[i - 1][j] + dp[i][j - 1];}}return dp[n][m];
}int main() {int n, m;while (cin >> n >> m){cout << pathnum(n, m) << endl;}
}
相关文章:
![](https://img-blog.csdnimg.cn/direct/f8aac76e18fb41ab968b561d22d00a3c.png)
【C++】笔试训练(九)
目录 一、选择题二、编程题1、另类加法2、走方格的方案数 一、选择题 1、某函数申明如下 void Func(int& nVal1);有int a,下面使用正确的为() A Func(a) B Func(&a) C Func(*a) D Func(&(*a)) 答案:A 2、C语言中,类…...
![](https://img-blog.csdnimg.cn/direct/813a639c60ad42e299516383638b74a5.png)
模板注入 [BJDCTF2020]Cookie is so stable1
打开题目 有flag页面,有Hint页面 这里题目有提示,突破口是在cookie上面 经过测试发现有ssti注入: 抓包 判断模板注入类型的办法 输入 {{7*‘7’}} 回显49 输入{{7*‘7’}},返回49表示是 Twig 模块 输入{{7*‘7’}}࿰…...
![](https://www.ngui.cc/images/no-images.jpg)
2-18算法习题总结
二分查找问题 [COCI 2011/2012 #5] EKO / 砍树 题目描述 伐木工人 Mirko 需要砍 M M M 米长的木材。对 Mirko 来说这是很简单的工作,因为他有一个漂亮的新伐木机,可以如野火一般砍伐森林。不过,Mirko 只被允许砍伐一排树。 Mirko 的伐木…...
![](https://www.ngui.cc/images/no-images.jpg)
【软考高项】【英语知识】-- 单词积累
目录 一、常见计算机技术词汇 二、项目管理词汇 2.1 十大知识域 2.2 五大过程组 2.3 49个子过程 2.4 工具和技术汇总 2.5 输入和输出汇总 一、常见计算机技术词汇 序号中文英文1云计算Cloud computing2云存储Cloud storage3云服务Cloud service4软件即服务SaaS5平台即服…...
![](https://img-blog.csdnimg.cn/01b9e59860c048f38c9ebefe0439c6b8.gif)
外包干了3个月,技术退步明显
先说一下自己的情况,本科生,19年通过校招进入广州某软件公司,干了接近4年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…...
![](https://img-blog.csdnimg.cn/direct/e6deaaa44a8a4f4c8d8b68e6cc0422f5.png#pic_center)
【ArcGIS微课1000例】0105:三维模型转体模型(导入sketchup转多面体为例)
文章目录 一、实验概述二、三维模型转多面体三、加载多面体数据四、注意事项一、实验概述 ArcGIS可以借助【导入3D文件】工具支持主流的三维模型导入。支持 3D Studio Max (.3ds)、VRML and GeoVRML 2.0 (.wrl)、SketchUp 6.0 (.skp)、OpenFlight 15.8 (.flt)、Collaborative …...
![](https://img-blog.csdnimg.cn/img_convert/bfef9505807897215abecd7c0c3de611.png)
创建型设计模式 - 原型设计模式 - JAVA
原型设计模式 一 .简介二. 案例三. 补充知识 前言 这是我在这个网站整理的笔记,有错误的地方请指出,关注我,接下来还会持续更新。 作者:神的孩子都在歌唱 一 .简介 原型模式提供了一种机制,可以将原始对象复制到新对象࿰…...
![](https://www.ngui.cc/images/no-images.jpg)
Squid代理:APT、PyPI和Docker的内网穿透解决方案
如果你是在内网环境,并且你知道一台服务器可以链接外网,可以通过Squid代理的方式更新apt、pypi、docker源。 你可以通过在服务器A(172.16.16.122,可上外网)上设置代理服务器来实现服务器B通过服务器A访问外部APT源的需…...
![](https://www.ngui.cc/images/no-images.jpg)
MYSQL--触发器
一:介绍: 1.触发器实际上就是一种特殊的存储过程,两者都能够在MYSQL当中完成特定的功能,存储在服务器上的特殊SQL片段,可以重复进行使用,提高复用性的一种功能.但是触发器并不需要进行调用,在使用DML操作的时候会自动的调用相关的触发器操作 2.触发器能够对于DML操作当中的,删除…...
![](https://img-blog.csdnimg.cn/direct/84e1bb301cff4d7085d47927a459b8fd.png#pic_center)
onnx 1.16 doc学习笔记四:python API-If和Scan
onnx作为一个通用格式,很少有中文教程,因此开一篇文章对onnx 1.16文档进行翻译与进一步解释, onnx 1.16官方文档:https://onnx.ai/onnx/intro/index.html](https://onnx.ai/onnx/intro/index.html), 如果觉得有收获&am…...
![](https://img-blog.csdnimg.cn/img_convert/1b344a495b4ee3c35b096f5ca51e33d6.png)
如何构建企业专属GPT
大语言模型(LLM)具有令人印象深刻的自然语言理解和生成能力, 2022年11月底OpenAI发布了ChatGPT,一跃成为人工智能AI领域的现象级应用。但由于LLM的训练数据集主要来源于互联网数据,企业私域信息并未被LLM所训练&#x…...
![](https://img-blog.csdnimg.cn/direct/a5a611f508d5483fb062f5101cc14695.png#pic_center)
知识积累(二):损失函数正则化与权重衰减
文章目录 1. 欧氏距离与L2范数1.1 常用的相似性度量 2. 什么是正则化?参考资料 本文只介绍 L2 正则化。 1. 欧氏距离与L2范数 欧氏距离也就是L2范数 1.1 常用的相似性度量 1)点积 2)余弦相似度 3)L1和L2 2. 什么是正则化&…...
![](https://img-blog.csdnimg.cn/direct/42b6fd8eb8594aaa9128ff74f9cdfdb2.png)
消息中间件-面试题
MQ选择 一、Kafka 1、消息队列如何保证消息可靠性 消息不重复 生产者控制消费者幂等消息不丢失 生产者发送,要确认broker收到并持久化broker确认消费者消费完,再删除消息2、kafka是什么 Kafka是一种高吞吐量、分布式、基于发布/订阅的消息中间件,是Apache的开源项目。broke…...
![](https://www.ngui.cc/images/no-images.jpg)
Python 将二维数组或矩阵变为三维
Python 将二维数组或矩阵变为三维 引言正文基础 拓展 引言 之前,我们已经介绍过了 Python 将一维数组或矩阵变为三维。然而,很多时候,我们也需要对二维矩阵进行操作,这里特来介绍一下如何将二维矩阵扩展为三维。 阅读这一篇前推…...
![](https://img-blog.csdnimg.cn/direct/0d171b1f9faf469ab26b830938862cae.png)
区块链与Solidity详细介绍及基本语法使用
一、区块链简介 区块链是一种分布式数据库技术,它以块的形式存储数据,并通过加密算法确保数据的安全性。每个块包含一系列交易,并通过哈希值与前一个块相连接,形成一个链式结构。这种结构使得数据难以被篡改,因为任何对…...
![](https://www.ngui.cc/images/no-images.jpg)
题目 1253: 老王赛马
题目描述: 赛马是一古老的游戏,早在公元前四世纪的中国,处在诸侯割据的状态,历史上称为“战国时期”。在魏国作官的孙膑,因为受到同僚庞涓的迫害,被齐国使臣救出后,到达齐国国都。 赛马是当时最受齐国贵族…...
![](https://img-blog.csdnimg.cn/direct/9df7625ee1c24d7b8138df97450854ea.png)
【MATLAB源码-第144期】基于matlab的蝴蝶优化算法(BOA)无人机三维路径规划,输出做短路径图和适应度曲线。
操作环境: MATLAB 2022a 1、算法描述 蝴蝶优化算法(Butterfly Optimization Algorithm, BOA)是基于蝴蝶觅食行为的一种新颖的群体智能算法。它通过模拟蝴蝶个体在寻找食物过程中的嗅觉导向行为以及随机飞行行为,来探索解空间…...
![](https://img-blog.csdnimg.cn/direct/52ffc1d4769a43be9fe9da89bcc7416d.jpeg)
地下管线管网三维建模工具MagicPipe3D V3.4.2发布
经纬管网建模系统MagicPipe3D,本地离线参数化构建地下管网三维模型(包括管道、接头、附属设施等),输出标准3DTiles服务、Obj模型等格式,支持Cesium、Unreal、Unity、Osg等引擎加载进行三维可视化、语义查询、专题分析&…...
![](https://img-blog.csdnimg.cn/direct/44ef9958a135432a8ada048c8039c66f.png)
糖尿病性视网膜病变(DR)的自动化检测和分期
糖尿病性视网膜病变(DR)的自动化检测和分期 提出背景DR的阶段及其特征 历年解法计算机视觉方法多分类方法 新的解法深度学习方法迁移学习大模型多模型集成全流程分析 总结特征1:图像分割特征2:疾病分级特征3:治疗建议生…...
![](https://img-blog.csdnimg.cn/direct/ed1c5859510640838b80061c8c035d4f.png)
C 标准库 - <errno.h>
在C语言编程中,<errno.h> 头文件扮演着至关重要的角色,它提供了一个全局变量 errno 以及一系列预定义宏,用于指示系统调用或库函数执行过程中发生的错误。这些宏有助于程序员诊断和处理运行时错误。 errno 变量 extern int errno;err…...
![](https://img-blog.csdnimg.cn/img_convert/6e5217dae38d0e823958a192191fa645.png)
基于springboot+vue的房屋租赁管理系统(前后端分离)
博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 主要内容:毕业设计(Javaweb项目|小程序|Pyt…...
![](https://img-blog.csdnimg.cn/img_convert/d5c31c37aa9dc57155febc47b6b128fa.jpeg)
Sora----打破虚实之间的最后一根枷锁----这扇门的背后是人类文明的晟阳还是最后的余晖
目录 一.Sora出道即巅峰 二.为何说Sora是该领域的巨头 三.Sora无敌的背后究竟有怎样先进的处理技术 1.Spacetime Latent Patches 潜变量时空碎片,建构视觉语言系统 2.扩散模型与Diffusion Transformer,组合成强大的信息提取器 3.DiT应用于潜变量时…...
![](https://www.ngui.cc/images/no-images.jpg)
C语言之static关键字详解
C语言之static关键字详解_c语言static-CSDN博客 1.变量 2.局部变量和全局变量 3.变量的作用域 4.变量的生命周期 二、static关键字的作用 三、static关键字修饰局部变量 四、static关键字修饰全局变量 五、static关键字修饰函数...
![](https://img-blog.csdnimg.cn/direct/1a1b25ef23cb415babce0dce3ac85664.png)
Redis高性能原理
redis大家都知道拥有很高的性能,每秒可以支持上万个请求,这里探讨下它高性能的原理。单线程架构和io多路复用技术。 一,单线程架构 单线程架构指的是命令执行核心线程是单线程的,数据持久化、同步、异步删除是其他线程在跑的。re…...
![](https://img-blog.csdnimg.cn/direct/b1b2d23a237c4a0da85dc72001aa89dd.png)
MSS与cwnd的关系,rwnd又是什么?
慢启动算法是指数递增的 这种指数增长的方式是慢启动算法的一个核心特点,它确保了TCP连接在开始传输数据时能够快速地探测网络的带宽容量,而又不至于过于激进导致网络拥塞。具体来说: 初始阶段:当TCP连接刚建立时,拥…...
![](https://img-blog.csdnimg.cn/direct/ac73cb38ba9e4f9caaa1e1a95b09f9bd.png)
解决两个MySQL5.7报错
目录 1.启动不了MySQL,报错缺少MSVCR120.dll去官网下载vcredist_x64.exe运行安装进入管理员CMD 2.本地计算机 上的 mysql 服务启动后停止。某些服务在未由其他服务或程序使用时将自动停止,Fatal error: Can‘t open and lock privilege tables: Table ‘…...
![](https://img-blog.csdnimg.cn/direct/6f21b60b46e84e9aaec5932e802046ae.jpeg)
[OpenAI]继ChatGPT后发布的Sora模型原理与体验通道
前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家:https://www.captainbed.cn/z ChatGPT体验地址 文章目录 前言OpenAI体验通道Spacetime Latent Patches 潜变量时空碎片, 建构视觉语言系统…...
![](https://img-blog.csdnimg.cn/3c97d4398cda48b8ba1a64b114508399.jpg)
机器人初识 —— 电机传动系统
一、背景 波士顿动力公司开发的机器人,其电机传动系统是其高性能和动态运动能力的核心部分。电机传动系统通常包括以下几个关键组件: 1. **电动马达**:波士顿动力的机器人采用了先进的电动马达作为主要的动力源,如伺服电机或步进…...
![](https://img-blog.csdnimg.cn/direct/952879a92c20490bb6b2d6761965cdd8.png)
安卓游戏开发之音频技术优劣分析
一、引言 在安卓游戏开发中,音频处理技术扮演着至关重要的角色,它不仅能够增强游戏的沉浸感和玩家体验,还能通过声音效果传达关键的游戏信息。以下将对几种常见的安卓游戏音频处理技术进行优劣分析,并结合应用场景来阐述其特点。 …...
![](https://www.ngui.cc/images/no-images.jpg)
在C语言中,设置Linux系统时间
C 语言中使用 mktime 函数和 stime 函数来处理时间。 处理之前,需要先获取当前的时间戳。并使用当前的时间戳生成struct tm,struct tm是C语言中用于表示日期和时间的结构体,通常用于在程序中操作和处理日期时间信息。它包含了以下成员变量&a…...
![](https://img-blog.csdnimg.cn/20190116222545902.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L1hpYW9tb19oYWE=,size_16,color_FFFFFF,t_70)
jsp网站开发标准/最新新闻事件今天国内大事
独立按键 使用独立按键时,请将开发板上面的J5跳线帽接到BTN端,此时为独立按键模式。 独立按键原理很简单,根据原理图 此时一旦按键按下,相应的I/O口就是接地状态,为低电平。 写单片机时我们都知道按键按下需要消抖&…...
![](/images/no-images.jpg)
营销网站建设公司地址/查收录网站
软件工程概述 软件的定义 软件是计算机程序、规程、以及运行计算机系统可能需要的相关文档和数据 或者说 软件是包括程序、数据和文档的完整集合 软件是一种具有抽象的逻辑实体 软件的开发是一种逻辑思维成熟的过程,而无明显的制造过程 软件的分类 按照划分方式的…...
![](/images/no-images.jpg)
泰州网站建设方案推广/电商网站订烟
质数又称素数。指在一个大于1的自然数中,除了1和此整数自身外,没法被其他自然数整除的数。或在所有比1大的整数中,除了1和它本身以外,不再有别的因数,这种整数叫做质数或素数。 换句话说,只有两个正因数(1和自己)的自然…...
![](/images/no-images.jpg)
简历做的很棒的网站/网站收录提交工具
JQ属性选取attr、prop、data的区别 ps:本人亲测,阿里云2核4G5M的服务器性价比很高,新用户一块多一天,老用户三块多一天,最高可以买三年,感兴趣的可以戳一下:阿里云折扣服务器 1、attr返回属性…...
![](https://img-blog.csdnimg.cn/img_convert/28ff957e9893f09938023c5f7b6cef3b.png)
wordpress站长邮箱/网络营销的方法有哪些
一般的超算的拓扑结构是若干个登陆节点若干个交换机大量计算CPU节点大量GPU计算节点一个(或若干个)存储节点管理节点。[1]其中存储节点的共享存储可以被所有节点访问。一般运作方式是,如果我的计算依赖非常共性的软件,我可以找超算…...
![](/images/no-images.jpg)
平湖新埭哪里有做网站的/外链发布平台
电脑史话(40)——窗含千秋雪凡使用过IBM PC机的人都知道,在DOS操作系统的控制下,无论让电脑干什么,都必须记住各种操作命令,在键盘上不停敲打,输入一大串文字字符,带来诸多不便。 1985年11月,微…...