0

0

C++ multiset怎么用 C++允许重复元素的集合容器详解【应用】

尼克

尼克

发布时间:2026-02-02 18:08:01

|

453人浏览过

|

来源于php中文网

原创

multiset是允许重复元素的有序关联容器,而set不允许重复;二者均基于红黑树实现、自动升序、支持O(log n)操作,但multiset特有erase(key)删除所有匹配项、equal_range()获取重复元素区间。

c++ multiset怎么用 c++允许重复元素的集合容器详解【应用】

multiset 是什么,和 set 有什么根本区别

multiset 是 C++ 标准库中基于红黑树实现的有序关联容器,它允许重复键值(即相同元素可多次插入),而 set 不允许。两者都自动维持元素升序排列、支持 O(log n) 插入/查找/删除,但底层行为差异直接影响使用逻辑:

  • multisetfind() 只返回一个匹配迭代器(不保证是第一个或最后一个)
  • count() 返回重复次数,equal_range() 才能拿到所有相同元素的区间
  • 迭代器不可修改所指元素(因为会破坏排序),但可修改其副本或用于 erase/insert

插入、遍历、删指定值的所有实例

插入和遍历和其他容器类似,但删除需特别注意“删一个”还是“删全部”:

  • insert(x) 总是成功,重复值照插不误
  • 遍历时用 for (const auto& v : ms) 得到升序序列,含重复
  • 删除单个匹配值:用 ms.erase(ms.find(x))(前提是 find() 不返回 end()
  • 删除所有匹配值:直接 ms.erase(x)(这是 multiset 特有的重载,set 没这个)
  • 删除某迭代器位置:ms.erase(it),只删一个
std::multiset ms = {1, 2, 2, 3, 3, 3};
ms.erase(3);          // 全部 3 被删,剩下 {1,2,2}
ms.insert(2);
// 现在是 {1,2,2,2},不是 {1,2,2,2,3}

如何安全获取所有重复元素的位置

不能依赖 find(),它只给一个;也不能用 lower_bound()/upper_bound() 自己算——容易越界或漏判。正确方式是统一用 equal_range()

  • 返回 std::pair,左闭右开区间
  • 若元素不存在,两个迭代器相等,都等于 end()
  • 区间内所有元素严格等于目标值,且已排序(当然,它们本来就是相等的)
auto range = ms.equal_range(2);
for (auto it = range.first; it != range.second; ++it) {
    std::cout << *it << " "; // 输出所有 2
}

性能与替代方案权衡:什么时候不该用 multiset

multiset 的树结构带来稳定对数复杂度,但常数较大,且不支持随机访问。以下场景要谨慎:

稿定AI社区
稿定AI社区

在线AI创意灵感社区

下载

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

  • 只需计数不需要有序遍历:用 std::unordered_map 更快,内存也更省
  • 插入后只查总数、不遍历具体元素:mapunordered_map + operator[] 足够
  • 需频繁按位置取第 k 小(如 TopK):考虑 std::priority_queue 或带索引的平衡树(如 pb_ds tree)
  • 元素类型重载了 operator 但语义不稳定(比如浮点比较未处理精度):会导致插入错位或 find 失败

真正需要 multiset 的典型场景是:既要自动排序,又要保留重复,并且得逐个访问这些重复值(比如事件时间戳队列、带优先级的待处理任务池)。

重复元素的“存在性”和“数量”是两回事,multiset 解决的是前者+顺序,后者只是附带能力;别把它当计数器用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

198

2023.11.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

532

2023.09.20

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

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

75

2025.09.05

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

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

36

2025.11.16

golang map原理
golang map原理

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

61

2025.11.17

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

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

42

2025.11.27

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

39

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

7

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

4

2026.02.02

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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