1 文章转载自https://blog.csdn.net/zangker/article/details/22984803 2 3 set里面有set_intersection(取集合交集)、set_union(取集合并集)、set_difference(取集合差集)、set_symmetric_difference(取集合对称差集)等函数。其中,关于函数的五个参数问题做一下小结: 4 5 1、这几个函数的前四个参数一样,只有第五个参数有多重版本。 6 7 2、EX1:set_union(A.begin(),A.end(),B.begin(),B.end(),inserter( C1 , C1.begin() ) );前四个参数依次是第一的集合的头尾,第二个集合的头尾。第五个参数的意思是将集合A、B取合集后的结果存入集合C中。 8 9 EX2:set_union(A.begin(),A.end(),B.begin(),B.end(),ostream_iterator<int>(cout," “));这里的第五个参数的意思是将A、B取合集后的结果直接输出,(cout," ")双引号里面是输出你想用来间隔集合元素的符号或是空格。 10 11 下面是set_union的原型: 12 13 template<class InputIterator1, class InputIterator2, class OutputIterator> 14 15 OutputIterator set_union( 16 17 InputIterator1_First1 , 18 19 InputIterator1_Last1 , 20 21 InputIterator2_First2 , 22 23 InputIterator2_Last2 , 24 25 OutputIterator_Result 26 27 ); 28 29 下面是例子: 30 <span style="font-family:Comic Sans MS;font-size:18px;">/*Description 31 集合的运算就是用给定的集合去指定新的集合。设A和B是集合,则它们的并差交补集分别定义如下: 32 A∪B={x|x∈A∨x∈B} 33 A∩B={x|x∈A∧x∈B} 34 A-B={x|x∈A∧x不属于 B} 35 SA ={x|x∈(A∪B)∧x 不属于A} 36 SB ={x|x∈(A∪B)∧x 不属于B} 37 <!--[endif]--> 38 Input 39 第一行输入一个正整数T,表示总共有T组测试数据。(T<=200) 40 然后下面有2T行,每一行都有n+1个数字,其中第一个数字是n(0<=n<=100),表示该行后面还有n个数字输入。 41 Output 42 对于每组测试数据,首先输出测试数据序号,”Case #.NO”, 43 接下来输出共7行,每行都是一个集合, 44 前2行分别输出集合A、B,接下5行来分别输出集合A、B的并(A u B)、交(A n B)、差(A – B)、补。 45 集合中的元素用“{}”扩起来,且元素之间用“, ”隔开。 46 Sample Input 47 1 48 4 1 2 3 1 49 0 50 Sample Output 51 Case# 1: 52 A = {1, 2, 3} 53 B = {} 54 A u B = {1, 2, 3} 55 A n B = {} 56 A - B = {1, 2, 3} 57 SA = {} 58 SB = {1, 2, 3} 59 */ 60 #include <iostream> 61 #include <set> 62 #include <algorithm> 63 #include <iterator> 64 using namespace std; 65 int main() 66 { 67 set<int>A; 68 set<int>B; 69 set<int>C1; 70 set<int>C2; 71 set<int>C3; 72 set<int>C4; 73 set<int>C5; 74 set<int>C6; 75 set<int>::iterator pos;/// 定义迭代器,作用是输出set元素 76 int count=0; 77 int A_i,B_i,n,m; 78 cin>>n; 79 while(n--) 80 { 81 count++; 82 cin>>A_i; 83 while(A_i--)///输入集合A 84 { 85 cin>>m; 86 A.insert(m); 87 } 88 cin>>B_i;///输入集合B 89 while(B_i--) 90 { 91 cin>>m; 92 B.insert(m); 93 } 94 95 cout<<"Case# "<<count<<":"<<endl; 96 97 cout<<"A = {"; 98 for(pos=A.begin(); pos!=A.end(); pos++)///迭代器的作用 99 { 100 if(pos!=A.begin())cout<<", "; 101 cout<<*pos;///迭代器的作用,迭代器是一种特殊的指针 102 } 103 cout<<"}"<<endl; 104 105 cout<<"B = {"; 106 for(pos=B.begin(); pos!=B.end(); pos++) 107 { 108 if(pos!=B.begin())cout<<", "; 109 cout<<*pos; 110 } 111 cout<<"}"<<endl; 112 113 set_union(A.begin(),A.end(),B.begin(),B.end(),inserter( C1 , C1.begin() ) ); /*取并集运算*/ 114 //set_union(A.begin(),A.end(),B.begin(),B.end(),ostream_iterator<int>(cout," ")); /*取并集运算*/ //其中ostream_iterator的头文件是iterator 115 cout<<"A u B = {"; 116 for(pos=C1.begin(); pos!=C1.end(); pos++) 117 { 118 if(pos!=C1.begin())cout<<", "; 119 cout<<*pos; 120 } 121 cout<<"}"<<endl; 122 123 set_intersection(A.begin(),A.end(),B.begin(),B.end(),inserter( C2 , C2.begin() )); /*取交集运算*/ 124 cout<<"A n B = {"; 125 for(pos=C2.begin(); pos!=C2.end(); pos++) 126 { 127 if(pos!=C2.begin())cout<<", "; 128 cout<<*pos; 129 } 130 cout<<"}"<<endl; 131 132 set_difference( A.begin(), A.end(),B.begin(), B.end(),inserter( C3, C3.begin() ) ); /*取差集运算*/ 133 cout<<"A - B = {"; 134 for(pos=C3.begin(); pos!=C3.end(); pos++) 135 { 136 if(pos!=C3.begin())cout<<", "; 137 cout<<*pos; 138 } 139 cout<<"}"<<endl; 140 141 set_difference(C1.begin(),C1.end(), A.begin(), A.end(),inserter( C4, C4.begin() ) );/*取差集运算*/ 142 cout<<"SA = {"; 143 for(pos=C4.begin(); pos!=C4.end(); pos++) 144 { 145 if(pos!=C4.begin())cout<<", "; 146 cout<<*pos; 147 } 148 cout<<"}"<<endl; 149 150 set_difference(C1.begin(),C1.end(), B.begin(), B.end(),inserter( C5, C5.begin() ) );/*取差集运算*/ 151 cout<<"SB = {"; 152 for(pos=C5.begin(); pos!=C5.end(); pos++) 153 { 154 if(pos!=C5.begin())cout<<", "; 155 cout<<*pos; 156 } 157 cout<<"}"<<endl; 158 159 set_symmetric_difference(A.begin(),A.end(),B.begin(),B.end(),inserter( C6 , C6.begin() ) );///取 对称差集运算 160 cout<<"A ⊕ B = {"; 161 for(pos=C6.begin(); pos!=C6.end(); pos++) 162 { 163 if(pos!=C6.begin())cout<<", "; 164 cout<<*pos; 165 } 166 cout<<"}"<<endl; 167 168 A.clear(); 169 B.clear();//各个集合清零,否则下次使用会出错 170 C1.clear(); 171 C2.clear(); 172 C3.clear(); 173 C4.clear(); 174 C5.clear(); 175 C6.clear(); 176 } 177 } 178 </span> 179 180 这是在实际中遇到的问题,记下来,以后用。(以上程序codeblocks编译通过)