map和set

一、介绍

之前的 vector list deque 是序列式容器,map set 是关联式容器,即不仅存数据,数据之间还有关联。

set 是 key 模型,map 是 key-val 模型,二者底层是红黑树。

二、set

set 无法存储相同的 key,作用是排序 + 去重

multiset 可以存储相同的 key,其 find 函数用于找到中序遍历的第一个 key

在构造函数中可以传入比较函数进行排序

值得注意的是插入函数返回的是一个 pair 绑定了插入元素的迭代器和是否插入成功

三、map

pair 是键值对,能一次返回两个值

在 map 里面,插入的 key-val 就是通过键值存储的,所以在 C++17 引入了一个新方法遍历 map

cpp 复制代码
map<string, string> dict;
for(auto [x, y] : dict)
{
    cout << x << ' ' << y;
}

迭代器获取 pair 后 x 赋值成 first,y 赋值成 second

重载 [] 也是非常重要有用的

实现代码:

cpp 复制代码
V& operator[](const K& key)
{
    return (*((insert(make_pair(key, mapped_type()))).first)).second;
}

用 key 和默认的 val 构成 pair 传给 insert 函数,函数返回迭代器,取出迭代器的第一个值 pair 的迭代器后返回 second

所以 [] 可以实现插入,插入+修改,修改的作用,不仅因为函数封装 insert,而且是 val 本身可以修改。

相关推荐
九转成圣2 分钟前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
SmartRadio5 分钟前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信
开发语言·网络·智能手机·esp32·长距离wifi
laowangpython19 分钟前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫22 分钟前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
_.Switch24 分钟前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI24 分钟前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
Brendan_00125 分钟前
JavaScript的Stomp.over
开发语言·javascript·ecmascript
念23425 分钟前
f5 shape分析
开发语言·javascript·ecmascript
苍穹之跃29 分钟前
某量JS逆向
开发语言·javascript·ecmascript
思茂信息29 分钟前
CST软件如何进行参数化扫描?
运维·开发语言·javascript·windows·ecmascript·软件工程·软件需求