0

0

c++如何使用std-set-intersection求交集_c++集合运算【技巧】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-16 21:39:31

|

919人浏览过

|

来源于php中文网

原创

std::set_intersection要求两输入范围已排序,是对有序迭代器范围的归并扫描;若容器无序(如unordered_set)或未排序,将返回空结果。

c++如何使用std-set-intersection求交集_c++集合运算【技巧】

std::set_intersection 要求两个输入范围必须已排序

它不是“对任意两个 std::set 求交”,而是对两个**已排序的迭代器范围**做归并扫描。哪怕你传的是 std::set<int>::begin()</int>std::set<int>::end()</int>,也只因 std::set 天然有序才“碰巧能用”——换成 std::vector 就得先 std::sort

常见错误现象:std::set_intersection 返回空结果,但手动检查发现明明有公共元素——大概率是其中一个容器没排序,或用了 std::unordered_set 这类无序容器直接传迭代器。

  • 使用场景:两个升序序列(如 std::setstd::vector 排好序后)求交集,且你希望复用已有内存(比如写入已有 std::vector 的预留空间)
  • 参数差异:第 5 个参数是输出迭代器,必须支持写入(如 std::back_inserter 或普通指针),不能是只读范围
  • 性能影响:时间复杂度 O(m + n),比遍历+查找快;但要求输入有序,否则预处理排序成本可能抵消优势

别直接往 std::set 里 insert set_intersection 的结果

std::set_intersection 不会自动去重或保持红黑树结构,它只是把交集元素按序“抄”出来。如果你目标是得到一个 std::set,最安全做法是先写入临时容器,再构造新 std::set

错误写法示例:std::set_intersection(a.begin(), a.end(), b.begin(), b.end(), my_set.begin()) —— my_set.begin() 是 const 迭代器,且 std::set 不支持随机写入;就算用 my_set.insert(...) 手动插,也得自己控制迭代器位置,极易越界或漏插。

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

会译·对照式翻译
会译·对照式翻译

会译是一款AI智能翻译浏览器插件,支持多语种对照式翻译

下载
  • 正确做法:用 std::vector 接收结果,再用该 vector 初始化新 std::set,或用 std::inserter(my_set, my_set.end())
  • 注意 std::inserter 内部调用 insert,对每个元素做 log(n) 查找,整体变成 O(k·log n),k 是交集大小;而先写 vector 再建 set 是 O(k + k·log k),通常更快
  • 如果原数据就是 std::set,且只需交集逻辑,其实直接遍历小的那个 set、在大的里面 find 更直观,代码更少、意图更清

std::set_intersection 对自定义类型必须提供严格弱序比较

如果你用的是 std::set<mystruct></mystruct>,那 std::set_intersection 传入的两个范围,必须用**同一个比较函数对象**,且该函数必须满足严格弱序(strict weak ordering)——比如不能只写 a.x ,必须是 <code>a.x 。

常见错误现象:程序崩溃、结果重复、漏元素,甚至 debug 版本断言失败。根本原因是比较逻辑不一致,导致归并过程误判“相等”或“小于”关系。

  • 务必确认:传给 std::set 构造的比较器,和传给 std::set_intersection 的第 6 个参数(可选)完全一致
  • 如果两个输入 range 来自不同容器(比如一个 std::set,一个排好序的 std::vector),它们的排序依据必须严格相同,否则结果不可靠
  • 用 lambda 时注意生命周期:若捕获局部变量,确保其在 set_intersection 执行期间仍有效

替代方案:用 set 的成员函数 find 更简单?

当一边是 std::set、另一边是小规模容器(比如 size find 往往比 std::set_intersection 更省事、更不容易出错。

例如:for (const auto& x : small_vec) { if (big_set.find(x) != big_set.end()) result.push_back(x); } —— 逻辑直白,不用管排序、不用配迭代器、不依赖额外头文件(<algorithm> 已隐含)。

  • 性能上:O(n·log m),n 是小容器大小,m 是 set 大小;而 set_intersection 是 O(n + m),但前提是两边都已排序且你愿意写一堆模板参数
  • 兼容性更好:不依赖输入是否“恰好有序”,也不怕自定义类型比较器漏传
  • 真正容易被忽略的点:std::set_intersection 的输出迭代器必须有足够的空间(或用 back_inserter),而手写循环天然适配任何输出方式(push、emplace、甚至直接处理)

相关文章

c++速学教程(入门到精通)
c++速学教程(入门到精通)

c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

410

2023.09.04

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

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

565

2023.09.20

chatgpt使用指南
chatgpt使用指南

本专题整合了chatgpt使用教程、新手使用说明等等相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

chatgpt官网入口地址合集
chatgpt官网入口地址合集

本专题整合了chatgpt官网入口地址、使用教程等内容,阅读专题下面的文章了解更多详细内容。

0

2026.03.16

minimax入口地址汇总
minimax入口地址汇总

本专题整合了minimax相关入口合集,阅读专题下面的文章了解更多详细地址。

4

2026.03.16

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

7

2026.03.16

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

114

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

141

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

396

2026.03.11

热门下载

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

精品课程

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

共94课时 | 11.5万人学习

C 教程
C 教程

共75课时 | 5.5万人学习

C++教程
C++教程

共115课时 | 22.2万人学习

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

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