zoukankan      html  css  js  c++  java
  • 关于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编译通过)

  • 相关阅读:
    Python高级语法:魔法函数
    Pytorch 中 model.eval() 和 with torch.no_grad() 的区别
    python progress包 介绍
    Pytorch 编写代码基本思想(代码框架与流程)
    微软开源工具包NNI:自动特征工程、NAS、超参调优、模型压缩
    Python中的内置函数:repr() 函数
    Pytorch:模型的保存与加载 torch.load()、torch.nn.Module.load_state_dict()
    torch.backends.cudnn.benchmark的设置技巧
    卷积操作的高速实现
    YOLO v1 ~ YOLO v5 论文解读和实现细节
  • 原文地址:https://www.cnblogs.com/nxopen2018/p/10957679.html
Copyright © 2011-2022 走看看