关联式容器
在之前的文章中接触过STL部分容器,例如:vector、list、deque等等,这些容器统称为序列式容器,也称为顺序容器。
关联式容器和顺序容器有着根本的不同:关联容器中的元素是按照关键字来保存和访问的;而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的。
关联容器是用来存储数据的,与顺序容器不同的是,其里面存储的是< key,value >结构的键值对应,在数据检索时比序列容器效率更高。
关联式容器支持高效的关键字查找和访问。俩个主要的关联容器是map和set。map中的元素是一些关键字-值(key-value)对:关键字起到索引的作用,值则表示与索引相关联的数据;set中每一个元素只包含一个关键字,set支持高效的关键字查询操作:检查一个给定关键字是否在set中。
键值对
用来表示具有一一对应关系的一种结构,该结构中一般只包含包含俩个成员变量key与value,key代表键值,value代表与key对应的信息。
SGI-STL中键值对的定义:
template <class T1, class T2>
struct pair
{
typedef T1 first_type;
typedef T2 second_type;
T1 first;
T2 second;
pair() : first(T1()), second(T2())
{}
pair(const T1& a, const T2& b) : first(a), second(b)
{}
};
树形结构的关联式容器
在STL库中一共提供了8中关联容器,根据应用场景的不同,又可以将其分为俩种不同结构的管理式容器:树型结构与哈希结构。树型结构的关联式容器主要有四种:map、set、multimap、multiset。这四种容器的共同点是:使用平衡搜索树(即红黑树)作为底层结果,容器中的元素是一个有序的列表。
而在STL中的8个容器间的不同体现在三个不同维度上:
- 或者是一个set,或者是一个map;
- 或者要求不重复的关键字,或者允许重复关键字;
- 按顺序保存元素,或无序保存。
按照关键字有序保存元素 | |
---|---|
map | 关联数组;保存关键字-值对 |
set | 关键字即值,即只保存关键字的容器 |
multimap | 关键字可以重复出现的map |
multiset | 关键字可以重复出现的set |
无序排列 | |
---|---|
unordered_map | 用哈希函数组织的map |
unordered_set | 用哈希函数组织的set |
unordered_multimap | 哈希组织的map;关键字可以重复出现 |
unordered_multiset | 哈希组织的set;关键字可以重复出现 |
set
set的文档介绍
【解释说明】
- set是按照一定次序存储元素的容器。
- 在set中,元素的value也标识着(value就是key、类型是T),并且每个value必须是唯一的。set中的元素不能在容器中修改(元素总是const),但是可以从容器中插入或者删除它们。
- 在内部,set中的元素总是按照其内部比较对象(类型比较)所指示的特定严格弱排序准则进行排序。
- set容器通过key访问元素的速度通常比unordered_set容器慢,但它们允许根据顺序对子集进行直接迭代。
- set在底层是使用二叉搜索树(红黑树)实现的。
set的特殊作用是可以用于去重;其去重原理是:当值已经存在,就不进行插入。
set的使用
set的模板参数说明
在set的模板参数列表可以看到,set有三个模板参数,分别是:
- T:set中存放元素的类型,实际在底层存储< value , value >的键值对。
- compare:set中元素默认按照小于来比较。
- Alloc:set中元素空间的管理方式,使用STL提供的空间配置器管理。
set的构造
函数声明 | 功能介绍 |
---|---|
explicit set (const key_compare& comp = key_compare(), const allocator_type& alloc = allocator_type()); | 构造空的set |
template <class InputIterator> set (InputIterator first, InputIterator last, const key_compare& comp = key_compare(),const allocator_type& alloc = allocator_type()); |
同[first,lats)区间中的元素构造set |
set (const set& x); |
set的拷贝构造 |
set<int> s1;
int arr[] = { 1,2,3,4,5 };
set<int> s2(arr, arr + 5);
set<int> s3(s2);
set<int> s4(s2.begin(), s2.end());
set的迭代器
iterator begin();