0

0

C++中std::includes怎么判断集合包含关系_C++集合运算算法详解【逻辑】

穿越時空

穿越時空

发布时间:2026-02-14 19:05:15

|

975人浏览过

|

来源于php中文网

原创

std::includes判断有序序列的多重集包含关系,要求两范围均按相同规则升序排列,时间复杂度o(n+m);参数顺序为全集在前、子集在后,不处理未排序输入。

c++中std::includes怎么判断集合包含关系_c++集合运算算法详解【逻辑】

std::includes 判断的是「有序序列的子集关系」,不是容器类型意义上的包含

它不关心你用的是 std::vector 还是 std::set,只认两个已排序的范围 —— 如果第二个范围里的每个元素,在第一个范围内都能按序找到(允许重复,但顺序和相对频次不强制),就返回 true。本质是「是否能从第一个序列中按序挑出第二个序列的所有元素」,类似“子序列匹配”,但要求严格单调不降(因为输入必须升序)。

常见误用:拿两个未排序的 std::vector 直接传给 std::includes,结果不可预测 —— 它不会帮你排序,也不会报错,只是逻辑失效。

  • 必须确保两个输入范围都已用相同规则升序排列(比如都用 std::less<int></int>
  • 若用自定义比较器(如 std::greater<int></int>),两个范围都得按该规则排好序
  • std::setstd::map::key_set() 天然满足条件,可直接用其迭代器;std::vector 需先调用 std::sort

std::includes 的参数顺序不能颠倒:subset 在后,superset 在前

函数签名是 std::includes(first1, last1, first2, last2),其中 [first1, last1) 是被检查的「全集」,[first2, last2) 是待验证的「子集」。顺序反了会直接逻辑翻转 —— 比如你想查 A 是否包含 B,却写成 includes(B.begin(), B.end(), A.begin(), A.end()),那实际是在查 B 是否包含 A。

容易踩坑的点:

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

快剪魔方
快剪魔方

AI漫剧高效制作工具

下载
  • 变量命名模糊(如都叫 vec1, vec2)时极易传反
  • 配合 auto 推导迭代器时,没注意哪个容器更大,靠直觉传参
  • 在模板函数里泛化调用,忘记约束参数语义,导致运行时结果与预期相反

重复元素处理:std::includes 要求「频次覆盖」,不是集合去重意义上的包含

它不是数学集合论中的 ⊆,而是多重集(multiset)意义上的包含。例如:

std::vector<int> sup = {1, 2, 2, 3};  
std::vector<int> sub = {2, 2};  
// std::includes(sup.begin(), sup.end(), sub.begin(), sub.end()) → true  
std::vector<int> sub2 = {2, 2, 2};  
// → false,因为 sup 中只有两个 2

也就是说,std::includes 内部做的是双指针遍历:对 sub 中每个元素,在 sup 中找「下一个 ≥ 它」的位置,并消耗一个匹配项。所以:

  • 如果 sub 有重复值,sup 中对应值的出现次数必须不少于 sub 中的次数
  • 若想实现纯集合语义(忽略重复),需先用 std::unique + std::erase 去重,或改用 std::set 存储
  • 性能上,它是 O(n+m) 时间、O(1) 空间,比构造哈希表判断快,但前提是已排序

和 std::set_intersection、std::find_first_of 的关键区别在哪

std::includes 不产生新数据,只返回布尔结果;而 std::set_intersection 会把交集写入目标迭代器 —— 如果你只需要判断关系,用 includes 更轻量;如果后续还要用交集内容,别重复遍历两次。

std::find_first_of 是「是否存在任一匹配」,属于存在性判断;std::includes 是「全部元素都匹配」,属于全称判断。两者语义层级不同,不能互相替代。

  • 要查「B 中所有元素都在 A 里」→ 用 std::includes(A.begin(), A.end(), B.begin(), B.end())
  • 要查「B 中至少有一个元素在 A 里」→ 用 std::find_first_of(A.begin(), A.end(), B.begin(), B.end()) != A.end()
  • 要获取 A ∩ B 的具体元素 → 用 std::set_intersection,并确保输出空间足够

最易被忽略的一点:所有这些算法都依赖「已排序」前提。哪怕只漏掉一次 std::sort,或者比较器不一致(比如一个用默认 ,另一个用了 <code>std::greater),结果就完全不可信 —— 而且通常不崩溃,只是静默错误。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
Sass和less的区别
Sass和less的区别

Sass和less的区别有语法差异、变量和混合器的定义方式、导入方式、运算符的支持、扩展性等。本专题为大家提供Sass和less相关的文章、下载、课程内容,供大家免费下载体验。

211

2023.10.12

sort排序函数用法
sort排序函数用法

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

399

2023.09.04

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相关内容,阅读专题下面的文章了解更多详细内容。

66

2025.11.17

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

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

46

2025.11.27

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

448

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

76

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

49

2026.02.13

热门下载

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

精品课程

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

共94课时 | 9.4万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.7万人学习

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

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