码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • STL中map容器详解,对组类型的简单剖析。


    目录

    一:map容器中的元素类型

    对组(pair)

    结构介绍与简单图解

    二:map容器的元素填充

    填充规则

    插入数据的格式

    数据插入的规则

    map容器中元素的调用注意事项

    三:浅析map容器的底层


    一:map容器中的元素类型

    对于map容器来说,该容器存储的数据类型不是单一的泛型,而是对组类型,所以我们要了解map容器,就必须先了解对组的概念。

    对组(pair)

    对组是将一对值合成一个值,这一对值可以是不同的数据类型(当然也可以是相同的数据类型元素)。两个值可以分别使用pair的两个公有属性first和second去访问

    结构介绍与简单图解

    在C++中的struct和class是具有相同的作用,只不过struct的默认对外权限是公有权限,class的默认对外权限是私有权限。 

    对组的结构与单链表节点的结构类似,同样分为两个区域,一个是first(在map容器中也被称为键值),另一个是second(在map容器中被称为实值)。 

    二:map容器的元素填充

    填充规则

    map容器和set容器都是属于关联式容器,这两个类的对象在填充数据时,没有push_back和pop_back(没有头插,头删,和尾插,尾删)。他们填充元素的方法都是insert(插入)

    并且在进行数据的填充之后,每一个对组元素的键值是不允许修改的,因为他是根据键值的数值来进行自动排序的。如果修改了键值,会破坏map容器的整体结构。

    可以看到,它需要插入的对组类型就是刚才显示指定的对组类型。

    插入数据的格式

    这里简单介绍两种向map容器中插入对组的方式,小编在这里更推荐第二种(比较简便)。 

    数据插入的规则

    map容器在进行元素插入的时候,就会对元素进行排序,而排序使用的数据,就是对组元素中键值的大小(默认是从小到大排序规则,也可以指定其他排序规则。使用迭代器进行遍历时,遍历时的顺序是根据指定的排序规则遍历的)

    map容器中元素的调用注意事项

    首先呢,对于所有的STL容器来说,都可以使用迭代器进行元素的访问,但是在map容器这里也可以使用数组下标的方式去索引元素,只不过要注意的是,对应实值的数据的下标是它的键值。

    三:浅析map容器的底层

    map容器的数据结构是平衡搜索二叉树结构

    (1)平衡:二叉树上的每一根的左右两个两个子树的度差不能超过1.

    (2)搜索:二叉树上每一颗子树中结点的数据存储的大小顺序都是 左子<根<右子。

    这就是一个简单的平衡搜索二叉树。 这也是为什么map容器中,不能对对组元素的键值进行修改的原因了,如果对某一个键值进行修改,那么后续在对这个map容器进行搜索的时候,就会出现问题。

  • 相关阅读:
    SpringBoot不同环境加载不同配置文件(dev,sit,uat)
    centos 6.10 安装 python3.10.5 和 openssl1.1.1
    使用动态时间规整 (DTW) 解决时间序列相似性度量及河流上下游污染浓度相似性识别分析
    第四届“传智杯”全国大学生IT技能大赛(初赛A组) 补题
    Day02-网页布局实战
    R语言使用fs包的file_move函数对指定文件进行重命名(rename)、使用file_move函数将指定文件从一个位置拷贝(copy)到另一个位置
    基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(四)
    【LoRa-温湿度光照数据无线传输(点对多通讯)】
    ​​​​​​​Python---练习:打印直角三角形(利用wihle循环嵌套)
    c# Literals
  • 原文地址:https://blog.csdn.net/qq_51004011/article/details/126028331
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号