C++ set的使用方法详解

 更新时间:2017年10月16日 09:16:06   作者:_QING_FENG  
这篇文章主要介绍了C++ set的使用方法详解的相关资料,希望通过本文能帮助到大家,让大家理解掌握set的使用方法,需要的朋友可以参考下

C++ set的使用方法详解

set也是STL中比较常见的容器。set集合容器实现了红黑树的平衡二叉检索树的数据结构,它会自动调整二叉树的排列,把元素放到适当的位置。set容器所包含的元素的值是唯一的,集合中的元素按一定的顺序排列。

我们构造set集合的目的是为了快速的检索,不可直接去修改键值。

set的一些常见操作:

  1. begin() 返回指向第一个元素的迭代器
  2. clear() 清除所有元素
  3. count() 返回某个值元素的个数
  4. empty() 如果集合为空,返回true(真)
  5. end() 返回指向最后一个元素之后的迭代器,不是最后一个元素
  6. erase() 删除集合中的元素
  7. find() 返回一个指向被查找到元素的迭代器
  8. insert() 在集合中插入元素
  9. max_size() 返回集合能容纳的元素的最大限值
  10. size() 集合中元素的数目
  11. swap() 交换两个集合变量

其实set的大部分操作是与vector类似的,不过set不支持随机访问,必须要使用迭代器去访问。由于set放入一个元素就会调整这个元素的位置,把它放到合适的位置,所以set中只有一个insert插入操作。

对于集合来说,我们一般有并集、交集、差集、补集这几种操作,所以在set的操作中我们也有类似的集合操作,它们都在#include<algorithm>的头文件下:



std::set_intersection() :这个函数是求两个集合的交集。 
std::set_union() :求两个集合的并集 
std::set_difference():差集 
std::set_symmetric_difference():得到的结果是 第一个迭代器相对于第二个的差集 并上第二个相对于第一个的差集 

学校OJ上有一个题可以来进行这几个操作,下面是学校OJ的题:

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}

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

14 1 2 3 10

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}

我的代码如下:

#include<iostream> 
#include<set> 
#include<algorithm> 
#include<vector> 
using namespace std; 
void print(set<int> a) 
{ 
  if(a.begin() == a.end()) 
      cout << "}" << endl; 
  for(set<int>::iterator it = a.begin();it!=a.end();it++) 
  { 
    if(++it==a.end()) 
    { 
      it--; 
      cout << *it << "}\n"; 
    } 
    else 
    { 
      it--; 
      cout << *it << ", "; 
    } 
  } 
} 
int main() 
{ 
  int T, cou = 0; 
  set<int> a, b, c; 
  cin >> T; 
  while(T--) 
  { 
    cou++; 
    a.clear(), b.clear(), c.clear(); 
    int n; 
    cin >> n; 
    for(int i=0;i<n;i++) 
    { 
      int x; 
      cin >> x; 
      a.insert(x); 
    } 
    cin >> n; 
    for(int i=0;i<n;i++) 
    { 
      int x; 
      cin >> x; 
      b.insert(x); 
    } 
    cout << "Case# " << cou << ":" << endl; 
    cout << "A = {"; 
    print(a); 
    cout << "B = {"; 
    print(b); 
    set_union(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin())); 
    cout << "A u B = {"; 
    print(c); 
    c.clear(); 
    set_intersection(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin())); 
    cout << "A n B = {"; 
    print(c); 
    c.clear(); 
    set_difference(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin())); 
    cout << "A - B = {"; 
    print(c); 
    c.clear(); 
    set_difference(b.begin(),b.end(),a.begin(),a.end(),inserter(c,c.begin())); 
    cout << "SA = {"; 
    print(c); 
    c.clear(); 
    set_difference(a.begin(),a.end(),b.begin(),b.end(),inserter(c,c.begin())); 
    cout << "SB = {"; 
    print(c); 
  } 
 
  return 0; 
} 

inserter是一个迭代器适配器中的插入迭代器。原理:其内部调用insert()

功能:在容器的指定位置插入元素

限制:只有提供了inset()成员函数的容器中,inserter才能派上用场. 所有STL容器都提供了inset()函数.

适用:所有STL容器

如有疑问请留言或到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Android App仿微信界面切换时Tab图标变色效果的制作方法

    Android App仿微信界面切换时Tab图标变色效果的制作方法

    这篇文章主要介绍了Android App仿微信界面切换时Tab图标变色效果的制作方法,重点讲解了图标的绘制技巧,需要的朋友可以参考下
    2016-04-04
  • C/C++: Inline function, calloc 对比 malloc

    C/C++: Inline function, calloc 对比 malloc

    以下是对c/c++中的malloc函数与calloc函数的区别以及它们之间的联系进行了介绍,需要的朋友可以过来参考下
    2016-07-07
  • C++ 二维数组参数传递的实现方法

    C++ 二维数组参数传递的实现方法

    这篇文章主要介绍了C++ 二维数组参数传递的实现方法的相关资料,这里提供三种方法帮助大家实现这样的功能,需要的朋友可以参考下
    2017-08-08
  • C++加密解密php代码的方法

    C++加密解密php代码的方法

    这篇文章主要介绍了C++加密解密php代码的方法,实例分析了基于C++实现加密解密的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • C++如何获取当前系统时间及格式化输出

    C++如何获取当前系统时间及格式化输出

    这篇文章主要介绍了C++如何获取当前系统时间及格式化输出的实例代码,主要用到time()及strftime()函数,通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-02-02
  • VS2019如何创建C++项目的实现示例

    VS2019如何创建C++项目的实现示例

    这篇文章主要介绍了VS2019如何创建C++项目的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • C++ const引用、临时变量 引用参数详解

    C++ const引用、临时变量 引用参数详解

    下面小编就为大家带来一篇C++ const引用、临时变量 引用参数详解。小编觉得挺不错的现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • 关于《C和指针》的学习笔记

    关于《C和指针》的学习笔记

    本篇文章是对《C和指针》这本书的学习做了笔记介绍。需要的朋友参考下
    2013-05-05
  • C++中new的越界访问问题

    C++中new的越界访问问题

    越界访问指访问了不是程序申请的内存区域,比如申请了5个字节的char数组,结果读写数据的第六个元素,或者访问了释放后的内存等等。
    2016-04-04
  • 浅析C语言中的setjmp与longjmp函数

    浅析C语言中的setjmp与longjmp函数

    以下是对C语言中的setjmp与longjmp函数进行了详细的介绍,需要的朋友可以过来参考下
    2013-09-09

最新评论