• std::set


    创建set对象
    为了管理set的二叉树链表数据,先用set容器的构造函数,创建一个set对象
    (1) set()
    用默认的less<T>函数对象和内存分配器,创建一个没有任何数据元素的set对象。
    set<int> s; //创建了空的set对象s,元素类型为整型int;
    (2) set(const key_compare& comp)
    指定一个比较函数对象 comp 来创建set对象,内存分配器为默认值。
    //定义字符串比较函数对象 strLess
    struct strLess {
    bool operatro() (const char *s1, const char *s2) const
    {
    return strcmp(s1, s2) < 0;
    }
    };
    //创建set容器对象s
    set<const char*, strLess> s(strLess());
    (3)set(const set&)
    set拷贝构造函数,通过红黑树的拷贝构造函数,实现两个set容器的元素、头结点和节点个数的拷贝。
    //set<int> s1;
    set<int> s2 (s1);
    (4)set(InputIterator first, InputIterator last)
    用区间迭代器[first, last)所指的元素,创建一个set对象。
    int iArray = { 13, 32,19 };
    set<int> s(iArray, iArray+3);
    (5)set(InputIterator first, InputIterator last, const key_compare& comp)
    用区间迭代器[first, last)所指的元素和comp函数对象,创建一个set对象。
    const char* szArray = {"hello", "dog", "bird" };
    set<const char* , strLess> s(szArray, szArray+3, strLess() );

    元素的插入
    set没有尾部插入函数push_back(),元素的插入一般使用insert进行动态检索插入。
    (1)pair<iterator, bool> insert(const value_type& v)
    将元素v插入set容器,要求v值不与set容器的任何元素重复,否则插入失败。返回一个pair配对对象,提供所插入元素的迭代器位置和true/false插入成功标志。
    (2)iterator insert(iterator position, const value_type& v)
    将元素v插入set容器,参数position提示可在position位置之前插入v,所返回的插入位置视实际情况而定,不一定能在position位置之前插入。
    (3)void insert(inputIterator fist, InputIterator last)
    将某迭代器区间[first, last)所指的数据作为元素,插入到set容器。

    元素的删除
    与插入一样,set容器也具有高效的红黑树元素的删除处理, 并自动重新调整内部的红黑树平衡。
    (1) void erase(iterator position)
    删除position所指的元素
    (2)size_type erase(const key_type& k)
    删除等于键值k的那个元素,对于set容器来说,此函数总是返回值1, 因为set容器不会出现重复的元素值(键值)。
    (3)void erase(iterator first, iterator last)
    删除set迭代器区间[first, last)上的所有元素。
    (4)void clear()
    删除所有元素,但不会删除内部红黑树的头节点。

    元素的遍历访问
    set容器的迭代器提供了访问内部红黑树中元素的操作,通常先用begin和end函数找出遍历开始的首元素和结束元素,然后通过迭代器的“++”操作,有小到到大取出元素值。
    iterator begin();
    iterator end();

    元素的反向遍历
    利用set容器定义的方向迭代器reverse_iterator和const_reverse_iterator,可实现红黑树的逆中序遍历,从而将元素从大到小遍历出来。
    reverse_iterator rbegin();
    reverse_iterator rend();

    元素的搜索
    set容器提供了一个应用红黑树进行搜索的函数find,返回的迭代器值为搜索到的元素位置,如果元素不存在,则返回end结束元素位置
    iterator find(const key_type& k) const

    set的基本操作:

    begin() 返回指向第一个元素的迭代器

    clear() 清除所有元素

    count() 返回某个值元素的个数

    empty() 如果集合为空,返回true

    end() 返回指向最后一个元素的迭代器

    equal_range() 返回集合中与给定值相等的上下限的两个迭代器

    erase() 删除集合中的元素

    find() 返回一个指向被查找到元素的迭代器

    get_allocator() 返回集合的分配器

    insert() 在集合中插入元素

    lower_bound() 返回指向大于(或等于)某值的第一个元素的迭代器

    key_comp() 返回一个用于元素间值比较的函数

    max_size() 返回集合能容纳的元素的最大限值

    rbegin() 返回指向集合中最后一个元素的反向迭代器

    rend() 返回指向集合中第一个元素的反向迭代器

    size() 集合中元素的数目

    swap() 交换两个集合变量

    upper_bound() 返回大于某个值元素的迭代器

    value_comp() 返回一个用于比较元素间的值的函数

    5,自定义比较函数:

     1 #include<iostream>
     2 #include<set>
     3 using namespace std;
     4 typedef struct {
     5 int a,b;
     6 char s;
     7 }newtype;
     8 struct compare //there is no ().
     9 {
    10 bool operator()(const newtype &a, const newtype &b) const
    11 {
    12 return a.s<b.s;
    13 }
    14 };//the “; ” is here;
    15 set<newtype,compare>element;
    16 int main()
    17 {
    18 newtype a,b,c,d,t;
    19 a.a=1; a.s='b';
    20 b.a=2; b.s='c';
    21 c.a=4; c.s='d';
    22 d.a=3; d.s='a';
    23 element.insert(a);
    24 element.insert(b);
    25 element.insert(c);
    26 element.insert(d);
    27 set<newtype,compare>::iterator it;
    28 for(it=element.begin(); it!=element.end();it++)
    29 cout<<(*it).a<<" ";
    30 cout<<endl;
    31 for(it=element.begin(); it!=element.end();it++)
    32 cout<<(*it).s<<" ";
    33 }

    6.其他的set构造方法:

     1 #include <iostream>
     2 #include <set>
     3 using namespace std;
     4 bool fncomp (int lhs, int rhs) {return lhs<rhs;}
     5 struct classcomp {
     6  bool operator() (const int& lhs, const int& rhs) const
     7  {return lhs<rhs;}
     8 };
     9 int main ()
    10 {
    11  set<int> first; // empty set of ints
    12  int myints[]= {10,20,30,40,50};
    13  set<int> second (myints,myints+5); // pointers used as iterators
    14  set<int> third (second); // a copy of second
    15  set<int> fourth (second.begin(), second.end()); // iterator ctor.
    16  set<int,classcomp> fifth; // class as Compare
    17  bool(*fn_pt)(int,int) = fncomp;
    18  set<int,bool(*)(int,int)> sixth (fn_pt); // function pointer as Compare
    19  return 0;
    20 }
  • 相关阅读:
    TSINGSEE青犀视频AI智能识别功能开发如何通过GPU实现加速识别?
    沉浸式音视频互动要通过什么技术来实现?
    VR和AI进一步发展融合,智能视频的未来将会如何变革?
    什么样的安防摄像机才算是智能安防摄像机?
    编译EasyRTC新版本采用ProtocolBuffer(pb)接收不同类型数据如何判断?
    浅谈国内安防监控视频平台的未来发展和机遇
    摄像头接入EasyNVR和EasyCVR后视频流交互的区别在哪?
    新冠变异毒株来势汹汹,企业如何做好线上转型?
    推荐领域经典算法原理回顾 (LR / FMs / DT / GBDT / XGBoost)
    String字符串常量池
  • 原文地址:https://www.cnblogs.com/lpxblog/p/5064008.html
Copyright © 2020-2023  润新知