面试题复盘-2023/10/20

目录

  • 笔试题
  • 面试题(未完待续)

笔试题

一.多选题
A:map的key是const,不可更改
B:STL中的快速排序比一般的快速排序速度更快,是因为中值排序法
C:list的插入效率是O(1)
D:vector的容量只能增大不能减小

解析:
B: STL中的sort函数的特点是经过优化和根据数据集大小特性选择合适的排序算法
一般情况下,sort函数是使用的快速排序,但是当数据集比较小时,会出于性能考虑选择使用插入排序,当排序程度比较高时会选择选择排序,当数据集较大时,会选择堆排序……. 而且sort函数会对快速排序采用一系列策略优化,比如尾部递归,适应性的交换策略,非递归等.

C:
list在头部或者尾部插入元素时,时间复杂度是O(1) ,但是在中间插入元素时,你需要从头结点或者尾结点出发,来找到要插入的位置,所以时间复杂度是O(n)

D:vector的容量是可以减小的,当删除一个vector容器内的元素时,vector的容量会自动减小(具体取决于内存管理策略),减小到vector的大小+一部分内存. 比如说当前vector的大小是11,容量是16,当你删除一个元素之后,容量并不会降低至10,而是降低至12-14,保留一些额外的内存避免频繁的创建和销毁内存.

扩展:
1.当vector使用insert函数在中间插入时,会有一个内存拷贝的过程,会将所有插入元素后面的元素向后面移动一位,这是一个线性操作,所以说vector在中间插入新元素时的效率是O(n).

2.创建一个空vector,该vector的容量是0

二 看代码写结果

#include<bits/stdc++.h>
using namespace std;
class A
{public:virtual void func(){cout<<"A"<<endl;}
};
class B:public A
{public:void func(){cout<<"B"<<endl; }
};
void run(A a)
{a.func();
} 
int main()
{B b;run(b);
}

正确答案: A

这个题算是比较简单,但是我当时还是答错了,没看到run函数里面的不是指针类型,如果不是指针类型的话,调用虚函数也依然是调用自己类中的函数,而不是派生类中的函数.

三.看代码写结果

#include<bits/stdc++.h>
using namespace std;
int main()
{int a=0;decltype((a))b=a;b++;int c=1;int const& d=c>0?c:1;c=2;cout<<a<<b<<c<<d<<endl;
}

答案 1 1 2 1
这个题直接给我做晕了.

解析:
考点1:
decltype是自动进行类型推导的关键字,但是这里出题人挖了一个陷阱
如果decltype(a)的话那就相当于是 int b=a,但是如果是decltype((a)),那相当于是
int &b=a. 因为(a)的类型被判定是int &类型

考点2:
这种条件表达式 ?: 其实相当于一个函数,返回的是一个复制的值,而并不是变量本身
如图:
在这里插入图片描述
通过打印两个值的地址发现他们确实用的不是同一个地址,所以c的改变并不会影响d

扩展:
const int和int const在C++中是完全等价的,都表示一个常量整数
但是const int *和int const *是有区别的,一个是常量指针,一个是指针常量
常量指针:不能通过指针修改常量的值
指针常量:不能修改指针的指向

#include<bits/stdc++.h>
using namespace std;
int main()
{int a=1;const int &b=a;a++;cout<<a<<" "<<b<<endl;
}
//输出2 2

你可以用一个常量引用绑定一个非常量
但是不能用一个非常量引用去绑定一个常量

四,内存与CPU的关系
这个单独写一篇文章来讲解
链接:CPU与内存

面试题(未完待续)

1.定义一个结构体,设置成员变量int和string,使用socket将这个结构体发送出去,对方能否完整的收到int和string呢?

2.什么是线程安全,什么是线程安全类?

3.map是线程安全容器吗,其他容器是线程安全容器吗?

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

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

相关文章

Leetcode—66.加一【简单】

2023每日刷题&#xff08;十一&#xff09; Leetcode—66.加一 实现代码1 /*** Note: The returned array must be malloced, assume caller calls free().*/ int* plusOne(int* digits, int digitsSize, int* returnSize){int num 0;int i 0;int arr[110] {0};// 进位标识…

如何有效取代FTP来帮助企业快速传输大文件

在互联网的发展历史上&#xff0c;FTP是一种具有里程碑意义的协议&#xff0c;它最早出现在1971年&#xff0c;是实现网络上文件传输的基础。FTP的优点是简单、稳定、兼容性强&#xff0c;可以在不同的操作系统和平台之间进行文件交换。然而&#xff0c;时代在进步&#xff0c;…

Qwt QwtLegend和QwtPlotLegendItem图例类详解

1.概述 QwtLegend类是Qwt绘图库中用于显示图例的类。图例用于标识不同曲线、绘图元素或数据的意义&#xff0c;以便用户能够更好地理解图表中的数据。通过QwtLegend类&#xff0c;可以方便地在图表中添加、删除和设置图例的位置、方向和样式等属性。 QwtPlotLegendItem类是Qwt…

了解WebGL三维技术

文章目录 什么是WebGLWebGLOpenGL 什么是WebGL WebGL WebGL是一项结合了HTML5和JavaScript&#xff0c;用来在网页上绘制和渲染复杂三维图形的技术。WebGL通过JavaScript操作OpenGL接口的标准&#xff0c;把三维空间图像显示在二维的屏幕上。所以它的本质就是JavaScript操作O…

关于路由转发

路由表的作用 路由表的作用&#xff1a;目标网络匹配路由表&#xff0c;从相应网络转发&#xff1b;不匹配路由表&#xff0c;丢弃或转发至默认路由器。 路由转发的原理 根据IP地址找到目标网络&#xff0c;由应路由器解封装查看目标网络是否可达&#xff0c;重新封装进行转…

lunar-1.5.jar

公历农历转换包 https://mvnrepository.com/artifact/com.github.heqiao2010/lunar <!-- https://mvnrepository.com/artifact/com.github.heqiao2010/lunar --> <dependency> <groupId>com.github.heqiao2010</groupId> <artifactId>l…

three.js第一课

官网 1.创建场景 2.创建几何体 3.创建材质 4.创建网格模型 5.将几何体、材质加入网格模型&#xff0c;设置网格模型的位置&#xff0c;将网格模型加入场景中 6.创建相机&#xff0c;构造函数中设置角度、最后面视椎体的长宽比&#xff0c;相机离视椎体近端面的距离、视椎体的远…

设计模式(15)组合模式

一、介绍&#xff1a; 1、定义&#xff1a;组合多个对象形成树形结构以表示“整体-部分”的关系的层次结构。组合模式对叶子节点和容器节点的处理具有一致性&#xff0c;又称为整体-部分模式。 2、优缺点&#xff1a; 优点&#xff1a; &#xff08;1&#xff09;高层模块调…

33基于MATLAB的对RGB图像实现中值滤波,均值滤波,维纳滤波。程序已通过调试,可直接运行。

基于MATLAB的对RGB图像实现中值滤波&#xff0c;均值滤波&#xff0c;维纳滤波。程序已通过调试&#xff0c;可直接运行。 33 MATLAB、图像处理、维纳滤波 (xiaohongshu.com)

易基因: Nature Biotech:番茄细菌性青枯病的噬菌体联合治疗|国人佳作

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 生物防治是利用细菌接种剂来改变植物根际微生物群落的组成&#xff0c;但在以往研究中存在有接种的细菌在根际建立不良&#xff0c;与本地微生物组争夺资源&#xff0c;干扰本地微生物的…

Android Glide限定onlyRetrieveFromCache取内存缓存submit超时阻塞方式,Kotlin

Android Glide限定onlyRetrieveFromCache取内存缓存submit超时阻塞方式,Kotlin import android.os.Bundle import android.util.Log import android.widget.ImageView import androidx.appcompat.app.AppCompatActivity import androidx.lifecycle.lifecycleScope import com.b…

【Android】MQTT

目录 MQTT 协议简介应用场景优点缺点 部署服务端下载安装包启动服务器 搭建客户端下载SDK添加依赖配置MQTT服务和权限建立连接订阅主题发布消息取消订阅断开连接 MQTT客户端工具最终效果实现传感器数据采集与监测功能思路 MQTT 协议 简介 MQTT&#xff08;Message Queuing Te…

强化学习------PPO算法

目录 简介一、PPO原理1、由On-policy 转化为Off-policy2、Importance Sampling&#xff08;重要性采样&#xff09;3、off-policy下的梯度公式推导 二、PPO算法两种形式1、PPO-Penalty2、PPO-Clip 三、PPO算法实战四、参考 简介 PPO 算法之所以被提出&#xff0c;根本原因在于…

c++ qt连接操作sqlite

qt客户端编程,用到数据库的场景不多,但是部分项目还是需要数据库来保存同步数据,客户端用到的数据库,一般是sqlite。 Qt提供了数据库模块,但是qt本身的数据库模块并不好用,会有各种问题, 建议大家不要,可以自己封装数据库的操作。本篇博客介绍qt连接操作sqlite。 sqlit…

时间、空间复杂度的例题详解

文章前言 上篇文章带大家认识了数据结构和算法的含义&#xff0c;以及理解了时间、空间复杂度&#xff0c;那么接下来来深入理解一下时间、空间复杂度。 时间复杂度实例 实例1 // 计算Func2的时间复杂度&#xff1f; void Func2(int N) {int count 0;for (int k 0; k <…

【uniapp】富文本

1、富文本显示&#xff0c;只显示文字&#xff0c;其余html不显示 功能&#xff1a;红框处其实是一个富文本&#xff0c;有图片之类的。但是现在不想根据html显示&#xff0c;只显示文字。 直接上代码 //内容显示 <view>{{item.fhArticleVo.content}}</view> // …

Microsoft.Extensions 简介

Microsoft.Extensions 简介 一、Microsoft.Extensions 简介 .NET Extensions 是一套官方的、开源的、跨平台的 API 集合&#xff0c;提供了一些常用的编程模式和实用工具&#xff0c;例如依赖项注入、日志记录、缓存、Host以及配置等等。该项目的大多数 API 都被用在 .NET 平…

数据结构——排序算法(C语言)

本篇将详细讲一下以下排序算法&#xff1a; 直接插入排序希尔排序选择排序快速排序归并排序计数排序 排序的概念 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某写关键字的大小&#xff0c;按照递增或递减0排列起来的操作。 稳定性的概念…

“深入探讨操作系统和虚拟化技术“

目录 引言1.操作系统1.1.什么是操作系统1.2.常见操作系统1.3.个人版本和服务器版本的区别1.4.Linux的各个版本 2.安装VMWare虚拟机1.VMWare虚拟机介绍2.VMWare虚拟机安装3.VMWare虚拟机配置 3.安装配置Windows Server 2012 R24.完成电脑远程访问电脑5.服务器环境搭建配置jdk配置…

Python中的*args 和 **kwargs

在Python中的代码中经常会见到这两个词 args 和 kwargs&#xff0c;前面通常还会加上一个或者两个星号。其实这只是编程人员约定的变量名字&#xff0c;args 是 arguments 的缩写&#xff0c;表示位置参数&#xff1b;kwargs 是 keyword arguments 的缩写&#xff0c;表示关键字…