当前位置: 首页 > news >正文

【C++】常用集合算法

0.前言

在这里插入图片描述

1.set_intersection

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

#include <iostream>
using namespace std;// 常用集合算法 交集set_intersection
#include<vector>
#include<algorithm>void myPrint(int val)
{cout << val << " ";
}void test01()
{vector<int>v1, v2;for (int i = 0; i < 10; i++){v1.push_back(i);v2.push_back(i + 5);}vector<int>TargetV;TargetV.resize(min(v1.size(), v2.size()));vector<int>::iterator Itend = set_intersection(v1.begin(), v1.end(), v2.begin(), v2.end(), TargetV.begin());for_each(TargetV.begin(), Itend, myPrint);cout << endl;
}int main()
{test01();cout << "------------------------" << endl;//test02();//cout << "------------------------" << endl << endl;//test03();//**************************************system("pause");return 0;
} 

在这里插入图片描述

2.set_union

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

#include <iostream>
using namespace std;// 常用集合算法 并集set_union
#include<vector>
#include<algorithm>void myPrint(int val)
{cout << val << " ";
}void test01()
{vector<int>v1, v2;for (int i = 0; i < 10; i++){v1.push_back(i);v2.push_back(i + 5);}vector<int>TargetV;//目标容器提前开辟空间//最特殊情况 两个容器没有交集, 并集就是两个容器size相加TargetV.resize(v1.size() + v2.size());vector<int>::iterator itEnd = set_union(v1.begin(), v1.end(), v2.begin(), v2.end(), TargetV.begin());for_each(TargetV.begin(), itEnd, myPrint);cout << endl;
}int main()
{test01();cout << "------------------------" << endl;//test02();//cout << "------------------------" << endl << endl;//test03();//**************************************system("pause");return 0;
} 

在这里插入图片描述

3.set_difference

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

#include <iostream>
using namespace std;// 常用集合算法 差集set_difference
#include<vector>
#include<algorithm>void myPrint(int val)
{cout << val << " ";
}void test01()
{vector<int>v1, v2;for (int i = 0; i < 10; i++){v1.push_back(i);v2.push_back(i + 5);}vector<int>TargetV;//给目标容器开辟空间//最特殊情况 两个容器没有交集 取两个容器中大的size作为目标容器开辟空间TargetV.resize(max(v1.size(), v2.size()));vector<int>::iterator itEnd = set_difference(v2.begin(), v2.end(), v1.begin(), v1.end(), TargetV.begin());cout << "v2和v1的差集:" << endl;set_difference(v2.begin(), v2.end(), v1.begin(), v1.end(), TargetV.begin());for_each(TargetV.begin(), itEnd, myPrint);cout << endl;cout << "v1和v2的差集:" << endl;set_difference(v1.begin(), v1.end(), v2.begin(), v2.end(), TargetV.begin());for_each(TargetV.begin(), itEnd, myPrint);cout << endl;
}int main()
{test01();cout << "------------------------" << endl;//test02();//cout << "------------------------" << endl << endl;//test03();//**************************************system("pause");return 0;
} 

在这里插入图片描述

http://www.lryc.cn/news/166958.html

相关文章:

  • css flex:1;详解,配合demo效果解答
  • discuzQ安装
  • 深入解析NLP情感分析技术:从篇章到属性
  • JVM的双亲委派模型
  • js中如何判断一个变量是否为数字类型?
  • 使用阿里PAI DSW部署Stable Diffusion WebUI
  • redisson使用过程常见问题汇总
  • 代码随想录训练营 DP序列
  • Datastage部署与使用
  • 【实用工具】Centos 安装ARL灯塔
  • IP地址定位基础数据采集
  • leetcode做题笔记138. 复制带随机指针的链表
  • 分布式文件系统的新兴力量:揭秘Alluxio的元数据管理机制【文末送书】
  • ArcGIS标注的各种用法和示例
  • 修改ros中的控制器,便于仿真和驱动真实UR
  • 网络广播模块2*30W 智能4G广播终端开发模块
  • 优思学院|什么是精益项目管理?
  • 【Android取证篇】华为设备跳出“允许USB调试“界面方法的不同方法
  • 在VSCode中移除不必要的扩展
  • 算法刷题记录-树(LeetCode)
  • Linux中安装MySQL_图解_2023新
  • 生产设备上的静电该如何处理?
  • 山洪灾害预警方案(山洪预警解决方案的组成)
  • 数据库 MVCC 详解
  • process.nextTick和vue的nextTick区别
  • 小程序实现一个 倒计时组件
  • 【四万字】网络编程接口 Socket API 解读大全
  • 无涯教程-JavaScript - ISREF函数
  • Android:获取MAC < 安卓系统11 <= 获取UUID
  • 线程的几种状态