std::Set

Posted osbreak

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了std::Set相关的知识,希望对你有一定的参考价值。

set集合容器实现了红黑树(Red-Black Tree)的平衡二叉检索树的的数据结构,

在插入元素时,它会自动调整二叉树的排列,把该元素放到适当的位置,以确保每个子树根节点的键值大于左子树所有节点的键值,而小于右子树所有节点的键值;

另外,还得确保根节点的左子树的高度与有字数的高度相等,

这样,二叉树的高度最小,从而检索速度最快。

 

它不会重复插入相同键值的元素,而采取忽略处理。
平衡二叉检索树的检索使用中序遍历算法,
检索效率高于vector、deque、和list的容器。
平衡二叉检索树在插入元素时,就会自动将元素按键值从小到大的顺序排列。

 

set<int>::iterator it;             // 定义前向迭代器  
set<int>::reverse_iterator rit;    // 定义反向迭代器
it = s.erase(it++);                // 删除
it = s.find(6);                    // 查找的元素  
s.count(a)                         // 是否在集合中

 

如果元素不是结构体,那么可以编写比较函数。下面的程序比较规则为按键值从大到小的顺序插入到集合中。

技术分享图片
 1 #include<iostream>  
 2 #include<set>  
 3 using namespace std;  
 4 struct mycomp  
 5 { //自定义比较函数,重载“()”操作符  
 6     bool operator() (const int &a, const int &b)  
 7     {  
 8         if(a != b)  
 9             return a > b;  
10         else  
11             return a > b;  
12     }  
13 };  
14 int main()  
15 {  
16     set<int, mycomp> s; //采用比较函数mycomp  
17     s.insert(5); //第一次插入5,可以插入  
18     s.insert(1);  
19     s.insert(6);  
20     s.insert(3);  
21     s.insert(5); //第二次插入5,重复元素,不会插入  
22     set<int,mycomp>::iterator it;  
23     for(it = s.begin(); it != s.end(); it++)  
24         cout << *it << " ";  
25     cout << endl;  
26     return 0;  
27 }  
View Code

 

如果元素是结构体,那么可以直接把比较函数写在结构体内。

技术分享图片
 1 [cpp] view plain copy
 2 #include<iostream>  
 3 #include<set>  
 4 #include<string>  
 5 using namespace std;  
 6 struct Info  
 7 {  
 8     string name;  
 9     double score;  
10     bool operator < (const Info &a) const // 重载“<”操作符,自定义排序规则  
11     {  
12         //按score由大到小排序。如果要由小到大排序,使用“>”即可。  
13         return a.score < score;  
14     }  
15 };  
16 int main()  
17 {  
18     set<Info> s;  
19     Info info;  
20   
21     //插入三个元素  
22     info.name = "Jack";  
23     info.score = 80;  
24     s.insert(info);  
25 
26     info.name = "Tom";  
27     info.score = 99;  
28     s.insert(info);  
29 
30     info.name = "Steaven";  
31     info.score = 60;  
32     s.insert(info);  
33   
34     set<Info>::iterator it;  
35     for(it = s.begin(); it != s.end(); it++)  
36         cout << (*it).name << " : " << (*it).score << endl;   
37     return 0;  
38 }  
39 /* 
40 运行结果: 
41 Tom : 99 
42 Jack : 80 
43 Steaven : 60 
44 */  
View Code

 

以上是关于std::Set的主要内容,如果未能解决你的问题,请参考以下文章

调用 std::set<Type*>::find 时避免 const_cast

插入 std::set<std::tuple<std::string, ...>> 时重复

C++ std::set<,> operator怎么用

g++5 中 std::unordered_set 编译错误的不完整类型,在 clang++ 中编译

为啥 std:set (带有单个冒号)可以编译?

为啥 std::set::find 不提供提示迭代器?