zoukankan      html  css  js  c++  java
  • 关于C++里set_intersection(取集合交集)、set_union(取集合并集)、set_difference(取集合差集)等函数的使用总结

      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编译通过)
  • 相关阅读:
    applycationContext.xml文件配置信息
    原生json的异步操作
    解析xm文件
    druid(德鲁伊)连接池的DataSourceUtils的写法及原生写法
    MYSQL的JDBCUtils的写法
    模拟服务器
    关于函数式接口
    浅谈树和二叉树
    &和&&的区别
    全排列问题(c语言实现)
  • 原文地址:https://www.cnblogs.com/nxopen2018/p/10981702.html
Copyright © 2011-2022 走看看