【C++】关联容器

关联式容器

        在之前的文章中接触过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的文档介绍

【解释说明】

  1. set是按照一定次序存储元素的容器。
  2. 在set中,元素的value也标识着(value就是key、类型是T),并且每个value必须是唯一的。set中的元素不能在容器中修改(元素总是const),但是可以从容器中插入或者删除它们。
  3. 在内部,set中的元素总是按照其内部比较对象(类型比较)所指示的特定严格弱排序准则进行排序。
  4. set容器通过key访问元素的速度通常比unordered_set容器慢,但它们允许根据顺序对子集进行直接迭代。
  5. set在底层是使用二叉搜索树(红黑树)实现的。

set的特殊作用是可以用于去重;其去重原理是:当值已经存在,就不进行插入。

set的使用

set的模板参数说明

在set的模板参数列表可以看到,set有三个模板参数,分别是:

  • T:set中存放元素的类型,实际在底层存储< value , value >的键值对。
  • compare:set中元素默认按照小于来比较。
  • Alloc:set中元素空间的管理方式,使用STL提供的空间配置器管理。
set的构造

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();
评论 85
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值