0

0

C++ multimap如何使用 允许重复键的关联容器详解

P粉602998670

P粉602998670

发布时间:2025-07-28 11:46:01

|

601人浏览过

|

来源于php中文网

原创

c++++中,std::multimap用于存储多个相同键的关联容器。它允许插入多个相同键值,使用insert()函数可添加单个或批量元素;查找时需用equal_range()获取指定键的所有元素;遍历默认按键升序排列,也可自定义排序规则;删除时可用erase()删除特定位置或所有相同键元素,需注意迭代器失效问题。

C++ multimap如何使用 允许重复键的关联容器详解

在C++中,如果你需要一个能存储多个相同键的关联容器,std::multimap就是你要找的那个。它和std::map类似,但最大的区别在于:允许重复的键值。也就是说,你可以有多个相同的键对应不同的值。

C++ multimap如何使用 允许重复键的关联容器详解

这篇文章就来聊聊怎么用multimap,包括插入、查找、遍历这些常用操作,以及一些你可能会忽略的小细节。


插入元素:多种方式可以选

multimap支持多种插入方式,最常见的是使用insert()函数。你可以插入一个完整的键值对,也可以使用make_pair简化写法。

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

C++ multimap如何使用 允许重复键的关联容器详解

例如:

std::multimap mm;
mm.insert({1, "apple"});
mm.insert(std::make_pair(1, "orange"));

上面这段代码插入了两个键为1的元素。注意,multimap不会覆盖已有键,而是保留所有键值对。

C++ multimap如何使用 允许重复键的关联容器详解

如果你想插入多个元素,可以用范围插入:

std::vector> vec = {{2, "banana"}, {2, "grape"}};
mm.insert(vec.begin(), vec.end());

这样就可以批量添加内容了。


查找与访问:用equal_range是关键

因为multimap允许重复键,所以不能像map那样直接通过[]或者find()获取唯一的值。这时候需要用到equal_range()函数,它会返回一个pair,表示该键对应的所有元素的范围。

举个例子:

auto range = mm.equal_range(1);
for (auto it = range.first; it != range.second; ++it) {
    std::cout << it->second << std::endl;
}

这样就能遍历所有键为1的元素了。

Fotor AI Face Generator
Fotor AI Face Generator

Fotor 平台的在线 AI 头像生成器

下载

另外需要注意几点:

  • find()虽然也能找到某个键的第一个元素,但它只返回一个迭代器,无法获取全部。
  • 如果你想知道某个键是否存在,可以用count()函数判断数量是否大于0。

遍历元素:和map差不多,但顺序默认按键排序

multimap默认是按键升序排列的(底层实现是红黑树),所以遍历的时候也是按照键的顺序输出。

遍历方法如下:

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

如果你希望自定义排序规则,可以在声明时传入比较函数对象,比如降序:

std::multimap> mm;

这样键就会从大到小排列。


删除元素:要小心处理多个键的情况

删除multimap中的元素可以用erase()函数。如果只是删除一个特定位置的元素,可以直接传入迭代器:

auto it = mm.find(1);
if (it != mm.end()) {
    mm.erase(it);
}

但如果你想删除所有键为1的元素,建议用下面这种更稳妥的方式:

mm.erase(1);

这会一次性删除所有键等于1的元素。

需要注意的是,删除之后原来的迭代器可能失效,尤其是使用equal_range后,不要继续用之前的迭代器访问。


基本上就这些。multimap虽然比map复杂一点,但只要记住“允许多个相同键”这个核心点,在操作上稍作调整就可以了。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

193

2023.11.20

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

73

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

25

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

37

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

32

2025.11.27

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

150

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

88

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

90

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

61

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 2.7万人学习

Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Vue.js 微实战--十天技能课堂
Vue.js 微实战--十天技能课堂

共18课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号