前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >常用集合算法---求交集--set_intersection

常用集合算法---求交集--set_intersection

作者头像
大忽悠爱学习
发布2021-03-02 15:11:38
1.1K0
发布2021-03-02 15:11:38
举报
文章被收录于专栏:c++与qt学习
在这里插入图片描述
在这里插入图片描述

set_intersection求两个容器的交集

在这里插入图片描述
在这里插入图片描述

注意:

  1. 两个集合必须是有序序列,顺序一致(都是升序,都是倒序)
  2. 返回目标容器的是最后一个元素的迭代器地址,即接收集合数据的容器中最后一个元素的迭代器地址
代码语言:javascript
复制
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
class p {
public:
	void operator()(int val)
	{
		cout << val << " ";
	}
};
void test01()
{
	vector<int> v1 = { 1,2,3,4,5,6 };
	vector<int> v2 = { 4, 5, 6, 7, 8, 9, 10, 11, 12 };
	vector<int> v3;
	//min是标准算法头文件里面的一个函数
	//最特殊情况,大容器包含小容器,开辟空间取小容器的size即可
	v3.resize(min(v1.size(), v2.size()));
	//返回的是v3容器最后一个迭代器地址
	vector<int>::iterator v3end=set_intersection(v1.begin(), v1.end(), v2.begin(), v2.end(), v3.begin());
	cout << "打印v3容器全部元素:";
	for_each(v3.begin(), v3.end(), p());
	cout << endl;
	cout << "只打印集合部分:";
	for_each(v3.begin(), v3end, p());
}

int main()
{

	test01();
	system("pause");
	return 0;
}
在这里插入图片描述
在这里插入图片描述

自定义数据类型:

  1. 涉及到比较----重载==运算符,注意加上const让底层识别
  2. 写一个函数对象或者普通函数------bool类型,判断什么条件才算相等
在这里插入图片描述
在这里插入图片描述
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/02/21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档