关于C++里set_intersection(取集合交集)、set_union(取集合并集)、set_difference(取集合差集)等函数的使用总结
- 文章转载自https://blog.csdn.net/zangker/article/details/22984803
- set里面有set_intersection(取集合交集)、set_union(取集合并集)、set_difference(取集合差集)、set_symmetric_difference(取集合对称差集)等函数。其中,关于函数的五个参数问题做一下小结:
- 、这几个函数的前四个参数一样,只有第五个参数有多重版本。
- 、EX1:set_union(A.begin(),A.end(),B.begin(),B.end(),inserter( C1 , C1.begin() ) );前四个参数依次是第一的集合的头尾,第二个集合的头尾。第五个参数的意思是将集合A、B取合集后的结果存入集合C中。
- EX2:set_union(A.begin(),A.end(),B.begin(),B.end(),ostream_iterator<int>(cout," “));这里的第五个参数的意思是将A、B取合集后的结果直接输出,(cout," ")双引号里面是输出你想用来间隔集合元素的符号或是空格。
- 下面是set_union的原型:
- template<class InputIterator1, class InputIterator2, class OutputIterator>
- OutputIterator set_union(
- InputIterator1_First1 ,
- InputIterator1_Last1 ,
- InputIterator2_First2 ,
- InputIterator2_Last2 ,
- OutputIterator_Result
- );
- 下面是例子:
- <span style="font-family:Comic Sans MS;font-size:18px;">/*Description
- 集合的运算就是用给定的集合去指定新的集合。设A和B是集合,则它们的并差交补集分别定义如下:
- A∪B={x|x∈A∨x∈B}
- A∩B={x|x∈A∧x∈B}
- A-B={x|x∈A∧x不属于 B}
- SA ={x|x∈(A∪B)∧x 不属于A}
- SB ={x|x∈(A∪B)∧x 不属于B}
- <!--[endif]-->
- Input
- 第一行输入一个正整数T,表示总共有T组测试数据。(T<=200)
- 然后下面有2T行,每一行都有n+1个数字,其中第一个数字是n(0<=n<=100),表示该行后面还有n个数字输入。
- Output
- 对于每组测试数据,首先输出测试数据序号,”Case #.NO”,
- 接下来输出共7行,每行都是一个集合,
- 前2行分别输出集合A、B,接下5行来分别输出集合A、B的并(A u B)、交(A n B)、差(A – B)、补。
- 集合中的元素用“{}”扩起来,且元素之间用“, ”隔开。
- Sample Input
- 1
- 4 1 2 3 1
- 0
- Sample Output
- Case# 1:
- A = {1, 2, 3}
- B = {}
- A u B = {1, 2, 3}
- A n B = {}
- A - B = {1, 2, 3}
- SA = {}
- SB = {1, 2, 3}
- */
- #include <iostream>
- #include <set>
- #include <algorithm>
- #include <iterator>
- using namespace std;
- int main()
- {
- set<int>A;
- set<int>B;
- set<int>C1;
- set<int>C2;
- set<int>C3;
- set<int>C4;
- set<int>C5;
- set<int>C6;
- set<int>::iterator pos;/// 定义迭代器,作用是输出set元素
- int count=;
- int A_i,B_i,n,m;
- cin>>n;
- while(n--)
- {
- count++;
- cin>>A_i;
- while(A_i--)///输入集合A
- {
- cin>>m;
- A.insert(m);
- }
- cin>>B_i;///输入集合B
- while(B_i--)
- {
- cin>>m;
- B.insert(m);
- }
- cout<<"Case# "<<count<<":"<<endl;
- cout<<"A = {";
- for(pos=A.begin(); pos!=A.end(); pos++)///迭代器的作用
- {
- if(pos!=A.begin())cout<<", ";
- cout<<*pos;///迭代器的作用,迭代器是一种特殊的指针
- }
- cout<<"}"<<endl;
- cout<<"B = {";
- for(pos=B.begin(); pos!=B.end(); pos++)
- {
- if(pos!=B.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- set_union(A.begin(),A.end(),B.begin(),B.end(),inserter( C1 , C1.begin() ) ); /*取并集运算*/
- //set_union(A.begin(),A.end(),B.begin(),B.end(),ostream_iterator<int>(cout," ")); /*取并集运算*/ //其中ostream_iterator的头文件是iterator
- cout<<"A u B = {";
- for(pos=C1.begin(); pos!=C1.end(); pos++)
- {
- if(pos!=C1.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- set_intersection(A.begin(),A.end(),B.begin(),B.end(),inserter( C2 , C2.begin() )); /*取交集运算*/
- cout<<"A n B = {";
- for(pos=C2.begin(); pos!=C2.end(); pos++)
- {
- if(pos!=C2.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- set_difference( A.begin(), A.end(),B.begin(), B.end(),inserter( C3, C3.begin() ) ); /*取差集运算*/
- cout<<"A - B = {";
- for(pos=C3.begin(); pos!=C3.end(); pos++)
- {
- if(pos!=C3.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- set_difference(C1.begin(),C1.end(), A.begin(), A.end(),inserter( C4, C4.begin() ) );/*取差集运算*/
- cout<<"SA = {";
- for(pos=C4.begin(); pos!=C4.end(); pos++)
- {
- if(pos!=C4.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- set_difference(C1.begin(),C1.end(), B.begin(), B.end(),inserter( C5, C5.begin() ) );/*取差集运算*/
- cout<<"SB = {";
- for(pos=C5.begin(); pos!=C5.end(); pos++)
- {
- if(pos!=C5.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- set_symmetric_difference(A.begin(),A.end(),B.begin(),B.end(),inserter( C6 , C6.begin() ) );///取 对称差集运算
- cout<<"A ⊕ B = {";
- for(pos=C6.begin(); pos!=C6.end(); pos++)
- {
- if(pos!=C6.begin())cout<<", ";
- cout<<*pos;
- }
- cout<<"}"<<endl;
- A.clear();
- B.clear();//各个集合清零,否则下次使用会出错
- C1.clear();
- C2.clear();
- C3.clear();
- C4.clear();
- C5.clear();
- C6.clear();
- }
- }
- </span>
- 这是在实际中遇到的问题,记下来,以后用。(以上程序codeblocks编译通过)
关于C++里set_intersection(取集合交集)、set_union(取集合并集)、set_difference(取集合差集)等函数的使用总结的更多相关文章
- 几个STL算法:includes,set_difference、set_intersection、set_symmetric_difference、set_union, pre_permutation, next_permutation
includes: 测试有序序列中是否包含另一个序列的全部元素. template<class inputIterator1, class inputIterator2> bool inc ...
- C# List 集合 交集、并集、差集、去重, 对象集合、 对象、引用类型、交并差补、List<T>
关键词:C# List 集合 交集.并集.差集.去重, 对象集合. 对象.引用类型.交并差.List<T> 有时候看官网文档是最高效的学习方式! 一.简单集合 Intersect 交集, ...
- 集合、拆箱、装箱、自定义集合的foreach
集合部分 参考:http://msdn.microsoft.com/zh-cn/library/0ytkdh4s(v=vs.110).aspx 集合类型是诸如哈希表.队列.堆栈.包.字典和列表等数据集 ...
- 集合(Collection解析 Set List Map三大集合运用)
集合的概念: 集合是包含多个对象的简单对象,所包含的对象称为元素.集合里面可以包含任意多个对象,数量可以变化:同时对对象的类型也没有限制,也就是说集合里面的所有对象的类型可以相同,也 ...
- Java 集合详解 | 一篇文章解决Java 三大集合
更好阅读体验:Java 集合详解 | 一篇文章搞定Java 三大集合 好看的皮囊像是一个个容器,有趣的灵魂像是容器里的数据.接下来讲解Java集合数据容器. 文章篇幅有点长,还请耐心阅读.如只是为了解 ...
- 网络爬虫: 从allitebooks.com抓取书籍信息并从amazon.com抓取价格(2): 抓取allitebooks.com书籍信息及ISBN码
这一篇首先从allitebooks.com里抓取书籍列表的书籍信息和每本书对应的ISBN码. 一.分析需求和网站结构 allitebooks.com这个网站的结构很简单,分页+书籍列表+书籍详情页. ...
- c++ 集合的增删改查,与两集合的合并 缺陷(空间大小不灵活)
#if 1 #include <iostream> #include <stdlib.h> using namespace std; class List { public: ...
- 从上面的集合框架图可以看到,Java 集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射
从上面的集合框架图可以看到,Java 集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射.Collection 接口又有 3 ...
- [Python3] 013 集合:你不能两次进入同一个集合
目录 0. 集合的独白 1. 集合的创建 2. 集合的特性 (1) 概述 (2) 少废话,上例子 3. 集合的遍历 4. 集合内涵 5. 集合的内置方法 6. 可供集合使用的一些方法/函数 (1) 又 ...
随机推荐
- nginx自动切割日志脚本
#!/bin/bash savepath_log='/data/logs' nglogs='/data/logs' mkdir -p $savepath_log/$(date +%Y)/$(date ...
- ItunesConnect:苹果内购项目元数据缺失
问题描述: 添加内购的App审核时被拒,原因为:ios内购 元数据丢失 问题原因: 审核信息里的 “审核屏幕快照” 和 “备注” 要填写,不然就失败的. 示例图: 1.屏幕快照和审核备注都需要填写 ...
- s13 day3作业
ha_proxy配置文件修改程序ha_file 为存储配置信息的文件.运行的时候对该文件进行操作.1.查询信息:用户输入域名,获得域名相关信息2.修改配置文件:用户输入的格式应该为 {"ba ...
- python爬虫 mac下安装使用Fiddler
HTTP代理工具Fiddler Fiddler是一款强大Web调试工具,它能记录所有客户端和服务器的HTTP请求. Getting started 在安装之前需要准备Mono环境 If you don ...
- MySql精简
安装的是免安装版MySql 由于MySql是开源的,故下载的时候源码也会包含,如果单纯只是使用其功能,则可以将这些文件删除为MySql减肥 可以删除的文件有如下: 1.mysql-test 文件夹: ...
- git分布式版本控制系统权威指南学习笔记(五):git checkout
文章目录 分离头指针 通过cat可以查看当前的分支 通过branch查看当前分支 checkout commitId(真正的
- JAVA求回文数
Manacher算法(马拉车算法)时间复杂度O(n) 用过中心检测法(就是上面说的O(n2) O(n^2)O(n )的算法)的都知道对于奇数回文串和偶数回文串的处理是不同的,奇数回文串有2n+1 2n ...
- 前端(二十一)—— vue指令:文本类指令、避免页面闪烁、v-bind指令、v-on指令、v-model指令、条件渲染指令、列表渲染指令
文本类指令.v-bind指令.v-on指令.v-model指令.条件渲染指令.列表渲染指令 一.文本操作 v-text:文本变量 <p v-text='msg'></p> &l ...
- HBase启动错误提示别的机器60000已经存在
已经用cm 安装好了cdh,需要在上面添加HBase,并且做一个HBase故障转移功能,现在需要配置2个HMaster 在不同的机器上. 启动出现异常信息: 2015-12-23 14:44:38, ...
- PHPExcel导出工作蒲(多表合并)教程+详细代码解读
最近做了一个需求,导出统计数据,因为需要同时导出多个不同的统计数据,所以不能像以往导出数据列表一样去实现这个需求,刚好空下来就记录一下(PHPExcel导出Excel多sheet合并) 一.主要使用的 ...