C++候捷stl-视频笔记2

深度搜索list

在这里插入图片描述
list是双向链表:底部实现是环状双向链表
list内部除了存data之外,还要存一个前向指针prev和一个后向指针next
list的iterator,当迭代器++的时候,是从一个节点走到下一个节点,是通过访问next指针实现的
在这里插入图片描述
主要有两部分:一部分是一堆typedef,另一部分是操作符的重载
在这里插入图片描述
前置(prefix)++iter和后置(postfix)iter++,后置重载时有int参数。
左下角,为了向int ++看齐,前置可以两次++,所以重载返回引用,后置不允许两次++,所以不返回引用
在这里插入图片描述
GC++2.9中iterator需要传三个模板参数<T, T&, T*>,而GC++4.9中仅需要传一个模板参数
在这里插入图片描述
4.9继承关系更复杂

迭代器的设计原则和Iterator Traits的作用与设计

在这里插入图片描述
iterator_category()是看++,–,能不能跳来跳去,随机访问;
iterator_difference_type:两个迭代器区间距离的表示类型;(unsigned int)
value_type:元素类型
另外两种reference和pointer没有在C++标准库中使用过,但要写出来
在这里插入图片描述
指针也被看作是一种退化的iterator,但指针不是一个类,无法在类中定义5种associated types,因此需要一个萃取机,作为中间层,加以判断
在这里插入图片描述
在这里插入图片描述
利用偏特化分离出类和指针
在这里插入图片描述

vector深度搜索

Vector是动态数组,它会进行扩充,但不是原地扩充,而是当数组空间用完时,它会在某个地方重新分配内存空间(原来的两倍大小),再把先前的内容搬过去
底层通常包含三个指针成员:start(第一个元素的指针,起始位置)、finish(最后一个元素的下一个位置的指针,存储元素结束范围)和 end_of_storage(内存空间的末尾的下一个位置的指针)
在这里插入图片描述
在这里插入图片描述
vector是连续的,用指针就能当作iterator。然后借助前面介绍的iterator_traits的偏特化(范围的偏特化,从接收T变成接收指针T ),会把associated types里面的 value_type直接指定为T,而不是基于类的迭代器的I::value_type
在这里插入图片描述
在这里插入图片描述
GC++4.9版本的vector的iterator不再是GC++2.9版本的指针T
,而是vector::iterator,里面的成员变量_M_current实际上就是_Tp*

array、forward list深度搜索

TR1标准array
在这里插入图片描述
array没有构造函数ctor,析构函数dtor。需要指定array的大小。
将本来的数组变为容器array是因为要提供迭代器,迭代器就要提供相应的5种类型,以便于连接算法与容器

forward list和双向链表list类似,只不过是单向

deque、queue和stack深度搜索

在这里插入图片描述
首先有一个map(暂且称为控制中心),里面存储指针,指针指向各个缓冲区buffer,缓冲区是数组,具体存储数据。缓冲区是连续的,但是不同的缓冲区之间不是连续的,所以称为分段连续
前后扩充时,map增加指针指向新的内存快。控制中心map是内存不够时是2倍增长
看起来好像连续,实际上是分段的,每个buffer有一定长度

迭代器中的cur,first,last,node四个元素,first和last分别是一个buffer的起始和结束,node是控制中心中哪个buffer的指针,cur指向的是具体的元素值。,每次++,–走到边界时,通过node回到控制中心,跳到下一个缓冲区

GC++2.9
在这里插入图片描述
class deque创建出来的对象本身大小有40B(32位机器上),至于deque里面存储的数据占用的空间大小,是动态分配获得的,和对象本身大小无关
iterator16b, map_point(T**,本身是一个指针)4b, map_size(控制中心这个vector的大小)4b
在这里插入图片描述
指定迭代器的类型是随机存取的类型,可以跳跃的,这就是deque对外表现的假象(虽然deque底层不连续,是分段连续的,但提供了++,+8的操作体现出连续的假象):提供随机访问迭代器,可以在常数时间内对其元素进行随机访问
在这里插入图片描述
在这里插入图片描述
中间插入时,判断哪端元素少,决定元素向前移动还是向后移动

reference front()
{return *start;
}
reference back()
{iterator tmp = finish; // 迭代器tmp赋值为finish,finish指向最后一个元素的下一个位置--tmp;// 迭代器--,往前移动一格return *tmp; // 此时返回的是最后一个元素
}
size_type size() const
{return finish - start; // -操作符重载,看两者之间多少个buffer,buffer*大小,然后在分别加上finish本身和start本身的元素;是尾巴迭代器-头迭代器;// 
}// 两个迭代器之间的距离:指的是多少个元素在两个迭代器之间
difference_type operator-(const _Self& __x) const {return difference_type(buffer_size()) * (node - x.node - 1) + //-1减去起点的buffer(cur - first) /*末尾(当前)buffer的元素量*/ + (x.last - x.cur)/*起始buffer的元素量*/ ;
}

deque模拟连续

self& operator++() {++cur;if (cur == last) { // 到达一个buffer的边界// node是控制中心的节点set_node(node + 1); // 跳转到下一个buffer的起点cur = first;}return *this; 
}
self operator++(int)  {self tmp = *this;++*this;return tmp;
}
self& operator--() {if (cur == first) {set_node(node - 1);cur = last;}--cur;return *this;
}
self operator--(int) {self tmp = *this;--*this;return tmp;
}// 从一个buffer跳转到另一个buffer
void set_node(map_pointer new_node) {node = new_node;first = *new_node; // 指向新buffer的startlast = first + difference_type(buffer_size()); //指向新buffer的last
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
deque里面有四个成员变量:控制中心,控制中心大小,指向所有元素的头,指向所有元素尾
当控制中心vector空间满时,自动两倍扩充空间。把旧的元素拷贝进新vector的中间部分

queue默认内部有一个deque作为底层容器。不直接提供存储元素的能力,而是通过封装底层容器来实现队列的行为(先进先出(FIFO))

stack同理,实现先进后出(LIFO)

stack和queue可以选择list或者deque作为底层结构,都不允许遍历,不提供iterator,否则会干扰先进先出/先进后出规则

queue不可选择vector,stack可选择vector

stack和queue都不能选择set或map做底层结构

RB tree深度搜索

红黑树是一种自平衡的二叉搜索树,保持树的平衡
在这里插入图片描述
在这里插入图片描述
Key:表示红黑树节点的键(key)的类型。这是用来比较和排序节点的关键信息
Value:表示红黑树节点存储的值(value,这里value表示key和data的整体)的类型。每个节点包含一个键和一个值(data)
KeyOfValue:一个函数对象,用于从节点值中提取键。在红黑树中,节点的键是用来进行比较和排序的。通过 KeyOfValue,可以从节点的值中提取键,以确保正确的比较和排序
Compare:一个比较函数对象,用于定义节点之间的顺序关系。它用来比较节点的键值,从而实现红黑树的有序性。
allocate:一个分配器类型,用于管理红黑树节点的内存分配和释放
在这里插入图片描述
在这里插入图片描述
GC++4.9的实现,handle/body,可以参考effective c++条款31的知识点

set、multiset深度搜索

以rb_tree为底层,因此有元素自动排序特性,提供遍历操作iterators。提供了++操作

无法使用iterators改变元素值,因为key有严谨排列规则,底部是RB_tree的const iterator
在这里插入图片描述

map、multimap深度搜索

和set类似。但虽然无法使用iterators改变元素的key,但可以改变元素的data。因此map/multimap内部自动将user指定的key type设定为const,以便静止user对元素key赋值
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
map中的[] 操作符里面先调用lower_bound进行查找,然后再insert元素。比之间insert要慢

hashtable深度搜索

在这里插入图片描述
假设一个物体可能的变化有 2 32 2^{32} 232,理想情况则需要sizeof(T)* 2 32 2^{32} 232的空间存放

空间不足时,用编号%空间大小,放在余数的位置。两个元素折射的编号可能发生碰撞
在这里插入图片描述
如果发生碰撞,则变成一个链表。
但这样可能导致一个链表很长,搜寻很慢
因此当链表太长时,需要打散(如果元素的个数比篮子的个数多时,把篮子增大(选取2倍大附近的素数,已经写死)。元素落在的位置要重新计算)

Bucket篮子就是一个vector
在这里插入图片描述
Value:表示哈希表中存储的值的类型
Key:表示哈希表中存储的键的类型
HashFun:表示哈希函数的类型,定了计算键的哈希值的方法,它是一个函数对象(函数或函数指针),用于将键转换为哈希值
ExtractKey:表示从键值对中提取键的方法的类型,是一个函数对象,用于从键值对中提取键,它定义了哈希表如何获取键值对中的键。
EqualKey:表示键的相等比较方法的类型,是一个函数对象,用于判断两个键是否相等,它定义了哈希表中键的相等性比较。
在这里插入图片描述
在这里插入图片描述
数值本身当成编号
在这里插入图片描述
没有数学,不统一,目的是为了设计出一个够乱,即够散列的数字

unordered容器概念

在这里插入图片描述
使用时不保证元素的顺序,而是通过哈希表提供快速的查找性能。每个元素被映射到哈希表的一个桶中,这使得查找操作的时间复杂度较低

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

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

相关文章

NFS p.1 服务器的部署以及客户端与服务端的远程挂载

目录 介绍 应用 NFS的工作原理 NFS的使用 步骤 1、两台机子 2、安装 3、配置文件 4、实验 服务端 准备 启动服务&#xff1a; 客户端 准备 步骤 介绍 NFS&#xff08;Network File System&#xff0c;网络文件系统&#xff09;是一种古老的用于在UNIX/Linux主…

新宏观范式和产业趋势下,纷享销客如何助力企业出海?

出海&#xff0c;已不再是企业的“备胎”&#xff0c;而是必须面对的“大考”&#xff01;在这个全球化的大潮中&#xff0c;有的企业乘风破浪&#xff0c;勇攀高峰&#xff0c;也有的企业在异国他乡遭遇了“水土不服”。 面对“要么出海&#xff0c;要么出局”的抉择&#xff…

C++设计模式-策略模式

文章目录 27. 策略模式 运行在VS2022&#xff0c;x86&#xff0c;Debug下。 27. 策略模式 策略模式让算法的选择与使用独立开来&#xff0c;使得代码更灵活、可扩展和易维护。应用&#xff1a;如在游戏开发中&#xff0c;AI角色需要根据环境和条件做出不同的行为&#xff0c;如…

微型导轨在自动化制造中有哪些优势?

微型导轨在自动化制造中发挥重要作用&#xff0c;能够满足自动化设备制造中对精度要求较高的工艺环节。适用于自动装配线、自动检测设备和机器人操作等环节&#xff0c;推动了行业的进步与发展。那么&#xff0c;微型导轨在使用中有哪些优势呢&#xff1f; 1、精度高和稳定性强…

Vue之组件基础(插槽)

在HTML中&#xff0c;开发者可以在双标签内添加一些信息。而在Vue中&#xff0c;组件以标签的形式引用&#xff0c;那么如何在组件的标签内添加一些信息并将信息渲染到页面中呢?其实&#xff0c;Vue 提供了插槽&#xff0c;专门用来实现这样的效果。 一.什么是插槽 Vue为组件…

【会议征稿】2024年无人驾驶与智能传感技术国际学术会议(ADIST 2024)

2024年无人驾驶与智能传感技术国际学术会议&#xff08;ADIST 2024&#xff09;将于2024年6月28-30日在珠海召开。ADIST 2024旨在搭建学术资源共享平台&#xff0c;加强中外学术合作&#xff0c;促进自动驾驶和智能传感技术的发展&#xff0c;促进全球研究人员、开发人员、工程…

react、vue动态form表单

需求在日常开发中反复写form 是一种低效的开发效率&#xff0c;布局而且还不同这就需要我们对其封装 为了简单明了看懂代码&#xff0c;我这里没有组件&#xff0c;都放在一起&#xff0c;简单抽离相信作为大佬的你&#xff0c;可以自己完成&#xff0c; 一、首先我们做动态f…

PostgreSQL的学习心得和知识总结(一百四十四)|深入理解PostgreSQL数据库之sendTuples的实现原理及功能修改

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《PostgreSQL数据库内核分析》 2、参考书籍&#xff1a;《数据库事务处理的艺术&#xff1a;事务管理与并发控制》 3、PostgreSQL数据库仓库…

C# 类型系统

1. 隐式类型 c#允许使用 var 声明变量&#xff0c;编译期会通过初始化语句右侧的表达式推断出变量的类型。 // i is compiled as an int var i 5;// s is compiled as a string var s "Hello";// a is compiled as int[] var a new[] { 0, 1, 2 };// expr is co…

521源码网-免费网络教程-Cloudflare使用加速解析-优化大陆访问速度

Cloudfalre 加速解析是由 心有网络 向中国大陆用户提供的公共优化服务 接入服务节点: cf.13d7s.sit 接入使用方式类似于其它CDN的CNAME接入&#xff0c;可以为中国大陆用户访问Cloudflare网络节点大幅度加速&#xff0c;累计节点130 如何接入使用 Cloudflare 加速解析&#…

【机器学习300问】106、Inception网络结构如何设计的?这么设计的目的是什么?

谷歌的Inception网络&#xff0c;也被称为GoogLeNet&#xff0c;是Google在2014年推出的一种深度卷积神经网络&#xff08;CNN&#xff09;模型&#xff0c;在这之前的AlexNet、VGG等结构都是通过增大网络的深度&#xff08;层数&#xff09;来获得更好的训练效果&#xff0c;但…

阿里云 通过EIP实现VPC下的SNAT以及DNAT

192.168.0.85 有公网地址192.1680.95无公网地址 在192.168.0.85&#xff08;有公网地址服务器上操作&#xff09; #开启端口转发 echo "net.ipv4.ip_forward 1" >> /etc/sysctl.conf sysctl -p#仅允许192.168.0.95 iptables -t nat -I POSTROUTING -s 192.16…

【前缀和 记忆化搜索】LeetCode1444. 切披萨的方案数

本文涉及的基础知识点 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 动态规划 记忆化搜索 LeetCode1444. 切披萨的方案数 给你一个 rows x cols 大小的矩形披萨和一个整数 k &#xff0c;矩形包含两种字符&#xff1a; ‘A’ &#xff…

GEYA格亚GRT8-S1S2间歇性双时间循环继电器时间可调交流220V 24v

品牌 GEYA 型号 GRT8-S2 AC/DC12-240V 产地 中国大陆 颜色分类 GRT8-S1 A220,GRT8-S1 AC/DC12-240V,GRT8-S2 A220,GRT8-S2 AC/DC12-240V GRT8-S&#xff0c;循环延时&#xff0c;时间继电器&#xff1a;LED指示灯&#xff0c;触头容量大&#xff0c;电压超宽&#xff0…

某咨询公司的大数据解决方案介绍(32页PPT)

方案介绍&#xff1a; 本咨询公司的大数据平台解决方案以企业实际需求为出发点&#xff0c;结合先进的大数据技术和行业经验&#xff0c;为企业提供一站式的大数据服务。通过实时数据收集与处理、深度数据分析与挖掘、可视化数据展示以及灵活的数据应用与扩展&#xff0c;帮助…

25. 悲观锁 和 乐观锁

文章目录 悲观锁 和 乐观锁1.基于CAS实现乐观锁2.自旋锁2.1.不可重入自旋锁2.2.可重入自旋锁2.3.CLH自旋锁 悲观锁 和 乐观锁 Java中的synchronized就是悲观锁的一个实现&#xff0c;悲观锁可以确保无论哪个线程持有锁&#xff0c;都能独占式的访问临界区代码&#xff0c;虽然悲…

企业微信hook接口协议,ipad协议http,获取欢迎语列表

获取欢迎语列表 参数名必选类型说明uuid是String每个实例的唯一标识&#xff0c;根据uuid操作具体企业微信 请求示例 {"uuid":"3240fde0-45e2-48c0-90e8-cb098d0ebe43","offset":"","limit":10 } {"data": {&…

HTML静态网页成品作业(HTML+CSS)—— 冶金工程专业展望与介绍介绍网页(2个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有2个页面。 二、作品演示 三、代…

手机离线翻译哪个好?断网翻译也能超丝滑

有时在异国他乡&#xff0c;面对语言不通的窘境&#xff0c;即便是简单的对话也变得异常困难&#xff0c;真是挑战满满&#xff01; 然而&#xff0c;能离线翻译的软件让语言障碍不再是问题&#xff0c;不必依赖网络也能轻松进行翻译啦~ 只需下载所需的语言包&#xff0c;选择…

信息系统项目管理师0604:项目整合管理 — 历年考题(详细分析与讲解)

点击查看专栏目录 1、2017年11月第34题 项目经理张工带领团队编制项目管理计划,(34)不属于编制项目管理计划过程的依据。 A. 项目章程B. 事业环境因素C. 组织过程资产D. 工作分解结构【答案】D 【解析】考查的是编写项目管理计划的相关知识,需要掌握。编写项目管理计划的…