關於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(取集合對稱差集)等函數。其中,關於函數的五個參數問題做一下小結:

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編譯通過)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM