文章轉載自https://blog.csdn.net/zangker/article/details/22984803
set里面有set_intersection(取集合交集)、set_union(取集合並集)、set_difference(取集合差集)、set_symmetric_difference(取集合對稱差集)等函數。其中,關於函數的五個參數問題做一下小結:
1、這幾個函數的前四個參數一樣,只有第五個參數有多重版本。
2、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}
1 #include <iostream> 2 #include <set> 3 #include <algorithm> 4 #include <iterator> 5 using namespace std; 6 int main() 7 { 8 set<int>A; 9 set<int>B; 10 set<int>C1; 11 set<int>C2; 12 set<int>C3; 13 set<int>C4; 14 set<int>C5; 15 set<int>C6; 16 17 set<int>::iterator pos;/// 定義迭代器,作用是輸出set元素 18 int count=0; 19 int A_i,B_i,n,m; 20 cin>>n; 21 while(n--) 22 { 23 count++; 24 cin>>A_i; 25 while(A_i--)///輸入集合A 26 { 27 cin>>m; 28 A.insert(m); 29 } 30 cin>>B_i;///輸入集合B 31 while(B_i--) 32 { 33 cin>>m; 34 B.insert(m); 35 } 36 37 cout<<"Case# "<<count<<":"<<endl; 38 39 cout<<"A = {"; 40 for(pos=A.begin(); pos!=A.end(); pos++)///迭代器的作用 41 { 42 if(pos!=A.begin())cout<<", "; 43 cout<<*pos;///迭代器的作用,迭代器是一種特殊的指針 44 } 45 cout<<"}"<<endl; 46 47 cout<<"B = {"; 48 for(pos=B.begin(); pos!=B.end(); pos++) 49 { 50 if(pos!=B.begin())cout<<", "; 51 cout<<*pos; 52 } 53 cout<<"}"<<endl; 54 55 set_union(A.begin(),A.end(),B.begin(),B.end(),inserter( C1 , C1.begin() ) ); /*取並集運算*/ 56 //set_union(A.begin(),A.end(),B.begin(),B.end(),ostream_iterator<int>(cout," ")); /*取並集運算*/ //其中ostream_iterator的頭文件是iterator 57 cout<<"A u B = {"; 58 for(pos=C1.begin(); pos!=C1.end(); pos++) 59 { 60 if(pos!=C1.begin())cout<<", "; 61 cout<<*pos; 62 } 63 cout<<"}"<<endl; 64 65 set_intersection(A.begin(),A.end(),B.begin(),B.end(),inserter( C2 , C2.begin() )); /*取交集運算*/ 66 cout<<"A n B = {"; 67 for(pos=C2.begin(); pos!=C2.end(); pos++) 68 { 69 if(pos!=C2.begin())cout<<", "; 70 cout<<*pos; 71 } 72 cout<<"}"<<endl; 73 74 set_difference( A.begin(), A.end(),B.begin(), B.end(),inserter( C3, C3.begin() ) ); /*取差集運算*/ 75 cout<<"A - B = {"; 76 for(pos=C3.begin(); pos!=C3.end(); pos++) 77 { 78 if(pos!=C3.begin())cout<<", "; 79 cout<<*pos; 80 } 81 cout<<"}"<<endl; 82 83 set_difference(C1.begin(),C1.end(), A.begin(), A.end(),inserter( C4, C4.begin() ) );/*取差集運算*/ 84 cout<<"SA = {"; 85 for(pos=C4.begin(); pos!=C4.end(); pos++) 86 { 87 if(pos!=C4.begin())cout<<", "; 88 cout<<*pos; 89 } 90 cout<<"}"<<endl; 91 92 set_difference(C1.begin(),C1.end(), B.begin(), B.end(),inserter( C5, C5.begin() ) );/*取差集運算*/ 93 cout<<"SB = {"; 94 for(pos=C5.begin(); pos!=C5.end(); pos++) 95 { 96 if(pos!=C5.begin())cout<<", "; 97 cout<<*pos; 98 } 99 cout<<"}"<<endl; 100 101 set_symmetric_difference(A.begin(),A.end(),B.begin(),B.end(),inserter( C6 , C6.begin() ) );///取 對稱差集運算 102 cout<<"A ⊕ B = {"; 103 for(pos=C6.begin(); pos!=C6.end(); pos++) 104 { 105 if(pos!=C6.begin())cout<<", "; 106 cout<<*pos; 107 } 108 cout<<"}"<<endl; 109 110 A.clear(); 111 B.clear();//各個集合清零,否則下次使用會出錯 112 C1.clear(); 113 C2.clear(); 114 C3.clear(); 115 C4.clear(); 116 C5.clear(); 117 C6.clear(); 118 } 119 } 120 </span>
這是在實際中遇到的問題,記下來,以后用。(以上程序codeblocks編譯通過)
