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编译通过)