C++set取并集,交集,差集

C++set取并集,交集,差集
C++ set取并集,交集,差集
说明:在C++编程中,使⽤set集合时,常⽤到取并集,交集,差集功能。在算法库中,提供了三个函数可以快速进⾏这三个操作。
需要包含头⽂件:
#include<algorithm>
基本介绍
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(cout," “));这⾥的第五个参数的意思是将A、B取合集后的结果直接输出,(cout," ")双引号⾥⾯是输出你想⽤来间隔集合元素的符号或是空格。
例⼦
/*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
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=0;
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;///迭代器的作⽤,迭代器是⼀种特殊的指针
e-r图
}
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<<*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();
}
}
交集和并集实践例⼦
#include<bits/stdc++.h>
using namespace std;
int main()
{
set<int> srcPart;
set<int> dstPart;
srcPart.insert(1);
srcPart.insert(2);
srcPart.insert(3);
srcPart.insert(4);
srcPart.insert(5);
dstPart.insert(3);
dstPart.insert(4);
dstPart.insert(5);
dstPart.insert(6);
dstPart.insert(7);
检察官法全文
set<int> intersection;
set<int> convergence;
set_intersection(srcPart.begin(), d(), dstPart.begin(), d(),inserter(intersection, intersection.begin())); set_union(srcPart.begin(), d(), dstPart.begin(), d(),inserter(convergence, convergence.begin()));
set<int>::iterator iter;
for(iter = intersection.begin(); iter != d(); iter++){
cout <<*iter <<" ";
}
盂兰盆节cout << endl;
for(iter = convergence.begin(); iter != d(); iter++){
cout <<*iter <<" ";
}
return0;
}

本文发布于:2024-09-25 07:21:33,感谢您对本站的认可!

本文链接:https://www.17tex.com/xueshu/473189.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:集合   交集   运算
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议