C++如何使用map_C++ map使用方法

C++中map是基于红黑树的关联容器,自动按键排序存储键值对。需包含头文件,支持insert、下标、emplace插入;可用下标、find、at访问;支持迭代器遍历和erase删除;常用函数有size、empty、clear、count,适用于高效查找与有序场景。

c++如何使用map_c++ map使用方法

在C++中,map 是一个非常实用的关联容器,用于存储键值对(key-value pairs),并能根据键快速查找对应的值。它底层通常基于红黑树实现,元素会按照键自动排序。下面介绍 map 的基本使用方法,帮助你快速上手。

包含头文件与定义 map

使用 map 前需要包含头文件

,然后可以定义不同类型的 map:

#include

std::map myMap;

例如,创建一个以字符串为键、整数为值的 map:

std::map ageMap;

插入元素的几种方式

向 map 中添加数据有多种方法:

立即学习“C++免费学习笔记(深入)”;

使用 insert():插入键值对,适合批量或避免覆盖的情况
ageMap.insert(std::make_pair("Alice", 25));使用下标操作符 []:最简单直接的方式
ageMap["Bob"] = 30;
注意:如果键不存在,会自动创建;若已存在,则会更新其值。使用 emplace():原地构造,效率更高
ageMap.emplace("Charlie", 35);

访问和查找元素

可以通过键来获取对应的值:

使用下标 []:直接访问,但如果键不存在会自动插入一个默认值,需谨慎使用。
int aliceAge = ageMap["Alice"];使用 find():推荐用于判断键是否存在

auto it = ageMap.find("Alice");if (it != ageMap.end()) {    std::cout <first << ": " <second << std::endl;}

使用 at():带边界检查,键不存在时抛出异常
try { int val = ageMap.at("Alice"); } catch(…) { }

遍历 map

map 中的元素按键有序排列,可用迭代器或范围 for 循环遍历:

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

也可以使用迭代器:

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

删除元素

可以按键或迭代器删除元素:

ageMap.erase("Bob"); // 删除键为 “Bob” 的元素auto it = ageMap.find("Alice"); if (it != ageMap.end()) ageMap.erase(it);

常用成员函数

size():返回元素个数empty():判断是否为空clear():清空所有元素count(key):返回键是否存在(0 或 1)

基本上就这些。map 使用起来直观高效,特别适合需要按键查找、自动排序的场景。注意避免用下标访问不存在的键导致意外插入,默认构造可能带来性能或逻辑问题。掌握 insert、find 和遍历方式,就能应对大多数情况。

以上就是C++如何使用map_C++ map使用方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1476972.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 01:37:45
下一篇 2025年12月19日 01:38:00

相关推荐

发表回复

登录后才能评论
关注微信