一、介绍
set中的每一个元素只包含一个关键字:set支持高效的关键字查询操作 -> 检查一个给定的关键字是否在set中。
标准库提供的set
关联容器分为:
- 按关键字有序保存元素:
set
(关键字即值, 即只保存关键字的容器);multiset
(关键字可以重复出现的set) - 无序集合:
unordered_set
(用哈希函数组织的set
);unordered_multiset
(哈希组织的set,关键字可以重复出现)
set就是关键字的简单集合。当只想知道一个值是否存在时,set是最有用的。
在set中每个元素的值都唯一,而且系统根据元素的值自动进行排序。set中的元素的值不能直接被改变。
set内部采用的是一种非常高效的平衡检索二叉树——红黑树,也称为RB
树(Red-Black Tree)。RB树的统计性能要好于一般平衡二叉树。
set
具备的两个特点:
- set中的元素都是排好序的
- set中的元素都是唯一的,没有重复的
二、set
用法
操作 | 说明 |
---|---|
set s 或者 set s(b, e) | 初始化,其中,b 和 e 分别为迭代器开始和结束的标记(其中的参数b大多数情况下是数组) |
begin(); | 返回指向第一个元素的迭代器 |
end(); | 返回指向迭代器的最末尾处(即最后一个元素的下一个位置) |
clear(); | 清除所有元素 |
count(); | 返回某个值元素的个数 |
empty(); | 如果集合为空,返回true |
equal_range(); | 返回集合中与给定值相等的上下限的两个迭代器 |
erase() | 删除集合中的元素 |
find() | 返回一个指向被查找到元素的迭代器 |
get_allocator() | 返回集合的分配器 |
insert() | 在集合中插入元素 |
lower_bound() | 返回指向大于(或等于)某值的第一个元素的迭代器 |
key_comp() | 返回一个用于元素间值比较的函数 |
max_size() | 返回集合能容纳的元素的最大限值 |
rbegin() | 返回指向集合中最后一个元素的反向迭代器 |
rend() | 返回指向集合中第一个元素的反向迭代器 |
size() | 集合中元素的数目 |
swap() | 交换两个集合变量 |
upper_bound() | 返回大于某个值元素的迭代器 |
value_comp() | 返回一个用于比较元素间的值的函数 |
示例代码:
// begin() 和 end() 的使用
#include<iostream>
#include<set>
using namespace std;
int main(){
// 先定义一个整型数组
int int_array[] = {75, 23, 65, 42, 13, 13, 5, 2, 745, 412, 143};
// 迭代器开始的位置 int_array 就是数组首元素的地址
// 迭代器结束的位置 int_array + 5 就是右移5个位置的地址
// set<int> int_set(int_array, int_array + 5);
// 我们换个写法: sizeof(int_array) / sizeof(*int_array) 的意思: 数组占据内存空间大小/数组首元素占据空间大小 = 有几个元素, 即数组的元素个数
set<int> int_set(int_array, int_array + sizeof(int_array) / sizeof(*int_array));
cout << "set contains: ";
for(auto item = int_set.begin(); item != int_set.end(); ++item){
cout << " " << *item; // 解引用获取到item指向的对象值
}
cout << "\n";
}
// 输出结果:
// set contains: 2 5 13 23 42 65 75 143 412 745
// GDB调试结果:
(gdb) p int_set
$1 = std::set with 10 elements = {
[0] = 2,
[1] = 5,
[2] = 13,
[3] = 23,
[4] = 42,
[5] = 65,
[6] = 75,
[7] = 143,
[8] = 412,
[9] = 745
}
(gdb) *int_array
Undefined command: "". Try "help".
(gdb) p *int_array
$2 = 75
(gdb) call(sizeof(*int_array))
$3 = 4
(gdb) call(sizeof(int_array))
$4 = 44