面试题复盘-2023/10/20

news2024/10/5 23:39:37

目录

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

笔试题

一.多选题
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.coloradmin.cn/o/1139264.html

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

相关文章

Python教程总结版

目录 1. chr()和ord()的用法 2. input()——读取数据的转换 2.1 int(),float(),list() 数据转换 2.2 split()函数处理多个输入值 2.3 map()强制转换 1. chr()和ord()的用法 for i in range(65, 91): print(chr(i), end) # 控制台输出&#xff1a;ABCDEFGHIJKLMNOPQRSTUV…

关于高并发你必须知道的几个概念

&#x1f388;个人公众号:&#x1f388; :✨✨✨ 可为编程✨ &#x1f35f;&#x1f35f; &#x1f511;个人信条:&#x1f511; 为与不为皆为可为&#x1f335; &#x1f349;本篇简介:&#x1f349; 本篇记录高并发必须知道的几个概念&#xff0c;如有出入还望指正。 关注公众…

墨西哥专线港口通航情况

随着全球贸易的不断发展&#xff0c;墨西哥作为拉美地区的重要国家&#xff0c;其港口通航状况对于国际贸易具有重要意义。本文将从墨西哥专线港口的通航现状、通航瓶颈以及未来发展趋势等方面进行分析&#xff0c;以期为墨西哥港口的发展提供一些参考。 一、墨西哥专线港口的通…

使用Linux JumpServer 堡垒机进行远程访问

文章目录 前言1. 安装Jump server2. 本地访问jump server3. 安装 cpolar内网穿透软件4. 配置Jump server公网访问地址5. 公网远程访问Jump server6. 固定Jump server公网地址 前言 JumpServer 是广受欢迎的开源堡垒机&#xff0c;是符合 4A 规范的专业运维安全审计系统。JumpS…

有什么不起眼,却很挣钱的副业?

说两个真人真事儿&#xff1a; 1、我有一个表妹,去年生完孩子后,开始在家做视频剪辑工作。 主要是剪辑一些古装剧、家庭剧等视频,然后发布到抖音和快手等短视频平台。 她会把视频剪辑成一集一集的,先发布片段进行推广,如果用户觉得剧情吸引就提示他们可以付费购买全集。 我表妹…

JS:获取当前时间、计算2个时间的相差天数

前言 本文将介绍在js中对时间的一些操作&#xff0c;包括&#xff1a;获取当前的年、月、日&#xff1b;获取指定格式的时间&#xff1b;2个时间的相差天数等 基本操作 在js种可以使用特定的函数&#xff0c;获取当前的年、月、日等时间 date .getYear(); //获取当前年份(2…

动画云渲染要多少钱?云渲染怎么使用?

其实动画云渲染的具体费用会根据所使用的平台、渲染模式、渲染时间等因素而有所不同&#xff0c;具体还是要看你所使用的云渲染平台。下面我们以炫云云渲染为例&#xff0c;告诉你动画云渲染需要多少钱。 炫云云渲染是第一家实现一键云渲染的平台&#xff0c;是最早的一批云渲染…

公司给了个CheckStyle,还给公司一片红润

项目总监在管理项目时&#xff0c;会担心技术人员开发代码不规范的问题。如果人员少口头述说一下就好了。但是人员大呢?比如50人的大团队&#xff0c;如果一个一个去说那肯定不可能。所以就需要借助工具checkstyle了。checkstyle的介绍如下&#xff1a; “CheckStyle是SourceF…

腾讯联手警方重拳出击 《绝地求生》外挂首案告破

12月13日&#xff0c;闲游盒腾讯公司联手无锡江阴警方破获一起利用《绝地求生》游戏外挂非法谋利的重大案件&#xff0c;3名核心涉案犯罪嫌疑人全部落网&#xff0c;并对犯罪事实供认不讳。这是腾讯宣布获得《绝地求生》国服独家代理权以来&#xff0c;破获的首起《绝地求生》外…

整数转罗马数字-----题解报告

题目&#xff1a;力扣&#xff08;LeetCode&#xff09;官网 - 全球极客挚爱的技术成长平台 直接按照题目模拟过程即可 public String intToRoman(int num) {int []a{1000,900,500,400,100,90,50,40,10,9,5,4,1};String []b{"M","CM","D",&quo…

全志R528代码编译和烧录以及测试

代表编译 代码存在如下目录中:/home/workspace/tina-r528-v1.2 这里输入如下指令进行编译: su root source build/envsetup.sh lunch r528_evb2-tina make & packroottina-virtual-machine:/home/workspace/tina-r528-v1.2# source build/envsetup.sh Setup env done! …

最小生成树专题2 最小生成树-Kruskal算法

题目&#xff1a; 样例1&#xff1a; 输入 4 5 0 1 3 0 2 2 0 3 3 2 3 1 1 2 1 输出 4 样例2&#xff1a; 输入 3 1 0 1 1 输出 -1 思路&#xff1a; 由题意&#xff0c;我们看一下数据&#xff0c;可以知道&#xff0c;朴素版的 最小生成树&#xff0c;是使用 二维数组存储…

【python入门篇】条件表达式、循环(5)

这一章节讲python的条件表达式和循环放在一起来说&#xff0c;条件语句是通过判断条件是否成立&#xff0c;根据条件表达式的结果做出决策&#xff0c;控制不同代码块的执行。循环是一种重复执行某段代码的结构,通常被用于遍历或处理一组数据,或者重复执行一些代码直到满足某个…

设计模式:状态模式(C#、JAVA、JavaScript、C++、Python、Go、PHP)

上一篇《备忘录模式》 下一篇《访问者模式》 简介&#xff1a; 状态模式&#xff0c;它是一种对象行为型模式&#xff0c;它允许一个对象在其内部状态改变时改变它的行为。这种模式可以让一个对象的行为随着状态的改…

Docker安装及镜像源修改

Docker安装及镜像源修改 一、docker安装1、yum 包更新到最新2、安装需要的软件包&#xff0c; yum-util 提供yum-config-manager功能&#xff0c;另外两个是devicemapper驱动依赖的3、 设置yum源4、 安装docker&#xff0c;出现输入的界面都按 y5、 查看docker版本&#xff0c;…

2023年中国商用洗碗机产量、需求量、市场规模及行业前景分析[图]

商用洗碗机是餐厅、食堂、中央厨房、酒店等应用场景中不可或缺的洁净消毒设备。商用洗碗机一般用于商用目的&#xff0c;随着消费者对食品卫生日渐重视&#xff0c;中国商用洗碗机市场得到了快速发展。商用洗碗机分类洗碗机有多种形式按洗涤方式分&#xff0c;有喷淋式、叶轮式…

AI 数字人短视频变现及引流,轻松掌握流量密码

项目介绍 AI 数字人短视频就是利用 AI 数字人工具 &#xff0c;生成模仿真人的口播视频 &#xff0c;进行涨粉变现。常见的领域有情感 、 创业 、 育儿 、 书单等 &#xff0c;同一个视频可以发布到各大平台 &#xff0c;实现一 鱼多吃。 创业就卖思维类书籍 &#xff0c;育儿…

Android setText()错误

android.content.res.Resources$NotFoundException: String resource ID #0x0at android.content.res.Resources.getText(Resources.java:415)at android.widget.TextView.setText(TextView.java:6375) 出现场景&#xff1a;在RecycleView的 Override public void onBindViewHo…

MySQL数据库#6

Python操作mysql 在使用Python连接mysql之前我们需要先下载一个第三方的模块 pymysql的模块&#xff0c;导入后再进行操作。 操作步骤&#xff1a;1. 先连接mysql host&#xff0c;port&#xff0c;charset&#xff0c;username password 库&#xff0c;等等。 import pymysql…

RawNet 1-3 介绍

1. Overview RawNet: Advanced end-to-end deep neural network using raw waveforms for text-independent speaker verification &#xff08;RawNet 1&#xff09; 出自会议&#xff1a;INTERSPEECH 2019. &#xff08;论文链接&#xff1a;https://arxiv.org/pdf/1904.0…