关于C++里面使用set_union,set_intersection等函数的使用总结

转自:http://blog.csdn.net/zangker

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(cout," “));这里的第五个参数的意思是将A、B取合集后的结果直接输出,(cout," ")双引号里面是输出你想用来间隔集合元素的符号或是空格。

下面是set_union的原型:

template

OutputIterator set_union(

InputIterator1_First1,

InputIterator1_Last1,

InputIterator2_First2,

InputIterator2_Last2,

OutputIterator_Result

);

下面是例子:


 

[cpp] view plain copy print ?
  1. "font-family:Comic Sans MS;font-size:18px;">/*Description 
  2. 集合的运算就是用给定的集合去指定新的集合。设A和B是集合,则它们的并差交补集分别定义如下: 
  3. A∪B={x|x∈A∨x∈B} 
  4. A∩B={x|x∈A∧x∈B} 
  5. A-B={x|x∈A∧x不属于 B} 
  6. SA ={x|x∈(A∪B)∧x 不属于A} 
  7. SB ={x|x∈(A∪B)∧x 不属于B} 
  8.  
  9.  
  10.  
  11. Input 
  12. 第一行输入一个正整数T,表示总共有T组测试数据。(T<=200) 
  13. 然后下面有2T行,每一行都有n+1个数字,其中第一个数字是n(0<=n<=100),表示该行后面还有n个数字输入。 
  14.  
  15. Output 
  16. 对于每组测试数据,首先输出测试数据序号,”Case #.NO”, 
  17. 接下来输出共7行,每行都是一个集合, 
  18. 前2行分别输出集合A、B,接下5行来分别输出集合A、B的并(A u B)、交(A n B)、差(A – B)、补。 
  19. 集合中的元素用“{}”扩起来,且元素之间用“, ”隔开。 
  20.  
  21. Sample Input 
  22. 1 
  23. 4 1 2 3 1 
  24. 0 
  25.  
  26. Sample Output 
  27. Case# 1: 
  28. A = {1, 2, 3} 
  29. B = {} 
  30. A u B = {1, 2, 3} 
  31. A n B = {} 
  32. A - B = {1, 2, 3} 
  33. SA = {} 
  34. SB = {1, 2, 3} 
  35.  
  36. */  
  37. #include   
  38. #include   
  39. #include   
  40. #include   
  41. using namespace std;  
  42. int main()  
  43. {  
  44.     set<int>A;  
  45.     set<int>B;  
  46.     set<int>C1;  
  47.     set<int>C2;  
  48.     set<int>C3;  
  49.     set<int>C4;  
  50.     set<int>C5;  
  51.     set<int>C6;  
  52.   
  53.     set<int>::iterator pos;/// 定义迭代器,作用是输出set元素  
  54.     int count=0;  
  55.     int A_i,B_i,n,m;  
  56.     cin>>n;  
  57.     while(n--)  
  58.     {  
  59.         count++;  
  60.         cin>>A_i;  
  61.         while(A_i--)///输入集合A  
  62.         {  
  63.             cin>>m;  
  64.             A.insert(m);  
  65.         }  
  66.         cin>>B_i;///输入集合B  
  67.         while(B_i--)  
  68.         {  
  69.             cin>>m;  
  70.             B.insert(m);  
  71.         }  
  72.   
  73.         cout<<"Case# "<":"<
  74.   
  75.         cout<<"A = {";  
  76.         for(pos=A.begin(); pos!=A.end(); pos++)///迭代器的作用  
  77.         {  
  78.             if(pos!=A.begin())cout<<", ";  
  79.             cout<<*pos;///迭代器的作用,迭代器是一种特殊的指针  
  80.         }  
  81.         cout<<"}"<
  82.   
  83.         cout<<"B = {";  
  84.         for(pos=B.begin(); pos!=B.end(); pos++)  
  85.         {  
  86.             if(pos!=B.begin())cout<<", ";  
  87.             cout<<*pos;  
  88.         }  
  89.         cout<<"}"<
  90.   
  91.         set_union(A.begin(),A.end(),B.begin(),B.end(),inserter( C1 , C1.begin() ) );    /*取并集运算*/  
  92.         //set_union(A.begin(),A.end(),B.begin(),B.end(),ostream_iterator(cout," "));    /*取并集运算*/ //其中ostream_iterator的头文件是iterator  
  93.         cout<<"A u B = {";  
  94.         for(pos=C1.begin(); pos!=C1.end(); pos++)  
  95.         {  
  96.             if(pos!=C1.begin())cout<<", ";  
  97.             cout<<*pos;  
  98.         }  
  99.         cout<<"}"<
  100.   
  101.         set_intersection(A.begin(),A.end(),B.begin(),B.end(),inserter( C2 , C2.begin() ));    /*取交集运算*/  
  102.         cout<<"A n B = {";  
  103.         for(pos=C2.begin(); pos!=C2.end(); pos++)  
  104.         {  
  105.             if(pos!=C2.begin())cout<<", ";  
  106.             cout<<*pos;  
  107.         }  
  108.         cout<<"}"<
  109.   
  110.         set_difference( A.begin(), A.end(),B.begin(), B.end(),inserter( C3, C3.begin() ) );    /*取差集运算*/  
  111.         cout<<"A - B = {";  
  112.         for(pos=C3.begin(); pos!=C3.end(); pos++)  
  113.         {  
  114.             if(pos!=C3.begin())cout<<", ";  
  115.             cout<<*pos;  
  116.         }  
  117.         cout<<"}"<
  118.   
  119.         set_difference(C1.begin(),C1.end(), A.begin(), A.end(),inserter( C4, C4.begin() ) );/*取差集运算*/  
  120.         cout<<"SA = {";  
  121.         for(pos=C4.begin(); pos!=C4.end(); pos++)  
  122.         {  
  123.             if(pos!=C4.begin())cout<<", ";  
  124.             cout<<*pos;  
  125.         }  
  126.         cout<<"}"<
  127.   
  128.         set_difference(C1.begin(),C1.end(), B.begin(), B.end(),inserter( C5, C5.begin() ) );/*取差集运算*/  
  129.         cout<<"SB = {";  
  130.         for(pos=C5.begin(); pos!=C5.end(); pos++)  
  131.         {  
  132.             if(pos!=C5.begin())cout<<", ";  
  133.             cout<<*pos;  
  134.         }  
  135.         cout<<"}"<
  136.   
  137.         set_symmetric_difference(A.begin(),A.end(),B.begin(),B.end(),inserter( C6 , C6.begin() ) );///取 对称差集运算  
  138.         cout<<"A ⊕ B = {";  
  139.         for(pos=C6.begin(); pos!=C6.end(); pos++)  
  140.         {  
  141.             if(pos!=C6.begin())cout<<", ";  
  142.             cout<<*pos;  
  143.         }  
  144.         cout<<"}"<
  145.   
  146.         A.clear();  
  147.         B.clear();//各个集合清零,否则下次使用会出错  
  148.         C1.clear();  
  149.         C2.clear();  
  150.         C3.clear();  
  151.         C4.clear();  
  152.         C5.clear();  
  153.         C6.clear();  
  154.     }  
  155. }  
  156.   


这是在实际中遇到的问题,记下来,以后用。(以上程序codeblocks编译通过)


你可能感兴趣的:(#,模板)