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 }
原文地址:https://www.cnblogs.com/lpxblog/p/5064008.html