map是C++中基于红黑树的关联容器,自动按键排序,支持O(log n)查找、插入和删除;需包含<map>头文件,通过insert、emplace或下标添加元素,推荐at()安全访问,可用迭代器遍历,find查找,erase删除,并提供size、empty等常用函数。

在C++中,map 是一种关联容器,用于存储键值对(key-value pairs),其中每个键都唯一,并自动按照键的顺序排序。map 定义在 <map> 头文件中,属于 STL(标准模板库)的一部分。它底层通常基于红黑树实现,查找、插入和删除操作的时间复杂度为 O(log n)。
使用 map 前必须包含对应的头文件:
#include <map>定义一个 map 的通用格式如下:
std::map<KeyType, ValueType> mapName;例如:
立即学习“C++免费学习笔记(深入)”;
std::map<std::string, int> studentScores;这表示创建了一个以字符串为键、整数为值的 map,可用于存储学生姓名及其分数。
向 map 中添加键值对有多种方法:
注意:使用 [] 访问不存在的键时会自动插入该键并用默认值初始化(如 int 为 0),需小心误插入。
可以通过键直接访问值(使用 [] 或 at()):
int score = studentScores["Alice"]; // 若键不存在则插入推荐使用 at() 在只读场景中避免意外插入。
遍历 map 的常用方式是使用迭代器或范围 for 循环:
for (const auto& pair : studentScores) {由于 map 自动按键升序排列,遍历结果也是有序的。
使用 find() 查找指定键:
auto it = studentScores.find("Alice");也可以用 count() 判断键是否存在(map 中只能是 0 或 1):
if (studentScores.count("Bob")) {删除元素可使用 erase():
studentScores.erase("Alice"); // 按键删除这些函数在处理范围查询时非常有用。
基本上就这些。map 是 C++ 中处理键值映射关系最常用的容器之一,理解其特性有助于写出高效且安全的代码。注意键类型的可比较性(需支持
以上就是c++++中如何使用map_C++ map关联容器使用详解的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号