map,unordered_map,multimap,unordered_multimap

news/2024/9/19 20:05:35/文章来源:https://www.cnblogs.com/niumachen/p/18421240
  1. std::map(有序映射)
  2. std::unordered_map(无序映射)
  3. std::multimap(有序多重映射)
  4. std::unordered_multimap(无序多重映射)

它们的使用方式和特点略有不同,下面分别介绍这些数据结构及其基本用法。

1. std::map(有序映射)

std::map 是一个有序的键值对容器,键(key)是唯一的,并且按顺序(通常是按升序)排列。
它底层是用红黑树实现的,因此查找、插入、删除的时间复杂度为 O(log n)。

特点:

  • 有序性:键是有序的(按键的升序)。
  • 唯一性:键是唯一的。
  • 查找和插入的时间复杂度为 O(log n)。
    下面是std::map` 的基本用法介绍:

引入头文件

使用 std::map 需要引入 <map> 头文件:

#include <map>

创建 std::map

std::map 的基本语法是:

std::map<KeyType, ValueType> mapName;

例如:

std::map<int, std::string> myMap;

这将创建一个以 int 类型为键、std::string 类型为值的映射。

插入元素

  • 使用 [] 操作符插入元素:
myMap[1] = "One";
myMap[2] = "Two";
  • 使用 insert 函数插入元素:
myMap.insert({3, "Three"});
myMap.insert(std::make_pair(4, "Four"));

访问元素

  • 使用 [] 访问元素(如果键不存在,会插入一个默认值):
std::string value = myMap[1];  // 获取键为 1 的值
  • 使用 at 方法访问元素(如果键不存在,会抛出异常):
std::string value = myMap.at(2);

查找元素

  • 使用 find 方法查找键是否存在,返回一个迭代器。如果键不存在,则返回 map.end()
auto it = myMap.find(2);
if (it != myMap.end()) {std::cout << "Key 2 found, value: " << it->second << std::endl;
} else {std::cout << "Key 2 not found" << std::endl;
}

遍历 map

可以使用范围 for 循环或迭代器遍历 map

for (const auto& pair : myMap) {std::cout << pair.first << ": " << pair.second << std::endl;
}

或者使用迭代器:

for (auto it = myMap.begin(); it != myMap.end(); ++it) {std::cout << it->first << ": " << it->second << std::endl;
}

删除元素

  • 使用 erase 删除指定键:
myMap.erase(2);  // 删除键为 2 的元素
  • 使用迭代器删除:
auto it = myMap.find(3);
if (it != myMap.end()) {myMap.erase(it);  // 删除键为 3 的元素
}

获取 map 的大小和检查是否为空

  • 使用 size 获取 map 的大小:
std::cout << "Map size: " << myMap.size() << std::endl;
  • 使用 empty 检查是否为空:
if (myMap.empty()) {std::cout << "Map is empty" << std::endl;
}

示例代码

#include <iostream>
#include <map>int main() {// 创建一个 mapstd::map<int, std::string> myMap;// 插入元素myMap[1] = "One";myMap[2] = "Two";myMap.insert({3, "Three"});myMap.insert(std::make_pair(4, "Four"));// 访问元素std::cout << "Key 1 has value: " << myMap[1] << std::endl;std::cout << "Key 2 has value: " << myMap.at(2) << std::endl;// 查找元素auto it = myMap.find(3);if (it != myMap.end()) {std::cout << "Found key 3 with value: " << it->second << std::endl;}// 遍历 mapfor (const auto& pair : myMap) {std::cout << pair.first << ": " << pair.second << std::endl;}// 删除元素myMap.erase(2);// 显示删除后的 mapfor (const auto& pair : myMap) {std::cout << pair.first << ": " << pair.second << std::endl;}return 0;
}

2. std::unordered_map(无序映射)

std::unordered_map 是一个无序的键值对容器,键是唯一的,但它没有按顺序存储
它使用哈希表作为底层结构,查找、插入、删除的时间复杂度为 O(1)(均摊时间)。

特点:

  • 无序性:键没有特定顺序。
  • 唯一性:键是唯一的。
  • 查找和插入的时间复杂度在均摊情况下为 O(1)(最坏情况 O(n))。

3. std::multimap(有序多重映射)

std::multimap 是一个有序的键值对容器,允许多个相同的键。它类似于 std::map,但同一个键可以出现多次。

特点:

- 有序性:键是有序的。

  • 非唯一性:允许键重复。
  • 查找、插入的时间复杂度为 O(log n)。

4. std::unordered_multimap(无序多重映射)

std::unordered_multimap 是一个无序的键值对容器,也允许多个相同的键。它使用哈希表存储,但允许相同的键出现多次。

特点:

  • 无序性:键没有顺序。
  • 非唯一性:允许键重复。
  • 查找和插入的时间复杂度在均摊情况下为 O(1)(最坏情况 O(n))。

总结

  • std::map:有序且唯一键,底层实现为红黑树,查找和插入 O(log n)。
  • std::unordered_map:无序且唯一键,底层实现为哈希表,查找和插入 O(1)(均摊)。
  • std::multimap:有序且允许重复键,底层为红黑树,查找和插入 O(log n)。
  • std::unordered_multimap:无序且允许重复键,底层为哈希表,查找和插入 O(1)(均摊)。

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

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

相关文章

想做数据报表?你的“后台”够硬吗

在数据驱动的时代,制作一份高效、精准的数据报表成为企业管理和决策的重要手段。但要做好数据报表,不仅需要一款功能强大的报表工具,还必须有一个强有力的“后台”管理系统来支撑。那么,为什么报表工具需要一个管理后台?以及管理后台的核心功能有哪些?今天就带大家一探究…

centos789手动无脑用sh脚本安装Java8

#老师给的文件是jdk1.8版本,所以我这边写的也是1.8的脚本 输入命令:mkdir –p /export/data #放置相关的数据文件 输入命令mkdir –p /export/servers #软件的安装目录 输入命令:mkdir –p /export/software 上传文件jdk-8u241-linux-x64.tar.gz到/export/software目录 然后…

C++ vector 的一些操作

▲ 《C++ Primer》 P87▲ 《C++ Primer》 P91

BoardLight

​​这是一个easy程度的靶机,所以博主写的也很简单,总共有2个flag。 信息收集端口扫描: ​​发现开放了22,80端口 Web渗透 ​​最底部发现域名 board.htb写进/etc/hosts​文件中 sudo echo "10.10.11.11 board.htb" | sudo tee -a /etc/hosts 对他进行子域名爆破…

LLM学习笔记-长度外推技术

长度外推为在不需要对模型进行额外训练的情况下,模型可以处理更长的序列。本篇文章主要介绍目前大模型用到的一些长度外推技术,包括以RoPE为基础进行位置插值、NTK-aware、动态NTK、NTK-by-parts 和YaRN。关于RoPE,可参见我的上一篇博客LLM学习笔记-位置编码篇 位置插值 回想…

裘立帆-第一次作业

在博客园建立个人技术博客,完善个人信息及博客设置,并发布一篇包含自我介绍、技能树与技术偏好、课程期望的随笔,以此作为课程参与的开始。这个作业属于哪个课程 https://edu.cnblogs.com/campus/zjlg/rjjc/这个作业的目标 熟悉博客的写作和使用,将自己介绍给老师和助教姓名…

章14——集合——集合体系

目录两个难点 底层机制,和不同应用场景下的选择集合体系图,需要背诵!总结: 1、集合主要是两组(单列集合、双列集合) 2、Collection 接口有两个重要的子接口 List Set, 他们的实现子列都是单列集合 3、Map 接口实现的子类是双列集合,存放的是key,value 4、上述两张图要记…

使用 VSCode 调试 Zig

首要条件是你本地需要安装MinGW-w64. 可以参考MinGW-w64安装教程——著名C/C++编译器GCC的Windows版本 - jack_Meng - 博客园 (cnblogs.com) 这里有几点需要注意,在2024年9月时,我没有找exe的安装,你需要在github下载 Releases niXman/mingw-builds-binaries (github.com) …

Go 入门指南:8.5. map 的排序

原创 吃个大西瓜 Coding Big Tree2024年09月19日 08:00 云南map 默认是无序的,不管是按照 key 还是按照 value 默认都不排序(详见第 8.3 节)。 如果你想为 map 排序,需要将 key(或者 value)拷贝到一个切片,再对切片排序(使用 sort 包,详见第 7.6.6 节),然后可以使用…

频率响应9

频率响应 公式推导 正弦输入的一般形式 \[u(t)=Asin(\omega_i)+bcos(\omega_i) \]整理 \[u(t)=M_i sin(\omega_i t + \phi_i) \\其中 \phi_i=arctan \frac{B}{A} \qquad ,M_i=\sqrt{A^2+B^2} \]输入到系统 G(s) \[\begin{aligned} U(s)& =\mathcal{L}[u\left(t\right)]=\…

vscode 搜索框3个按钮分别代表什么

https://blog.csdn.net/u012292754/article/details/108307288相信坚持的力量,日复一日的习惯.