【C++】关联式容器——map、set、multimap、multiset

关联式容器也是用来存储数据的,与序列式容器不同的是,其里面存储的是结构的键值对,在数据检索时比序列式容器效率更高。

STL总共实现了两种不同结构的管理式容器:

  1. 树型结构
  2. 哈希结构

树型结构的关联式容器主要有四种:map、set、multimap、multiset。
这四种容器的共同点是:底层使用平衡搜索树(即红黑树),容器中的元素是一个有序的序列。

set特点:

  1. set是按照一定次序存储元素的容器,默认升序,使用set的迭代器遍历set中的元素,可以得到有序序列
  2. set中的元素不可以重复(set可以天然去重)
  3. set容器通过key访问单个元素的速度通常比unordered_set容器慢,因为哈希表的平均访问时间复杂度是O(1),但它们允许根据顺序对子集进行直接迭代
  4. 与map/multimap不同,map/multimap中存储的是真正的键值对set中只放value,但在底层实际存放的是由构成的键值对

map特点:

  1. 在map中,键值key通常用于排序和惟一地标识元素,而值value中存储与此键值key关联的内容
  2. 在map的内部,key与value通过成员类型value_type绑定在一起,为其取别名称为pair: typedef pair value_type;
  3. 在内部,map中的元素总是按照键值key进行比较排序的
  4. map中通过键值访问单个元素的速度通常比unordered_map容器慢
  5. 注意:在元素访问时,operator[]和at(),都是通过key找到与key对应的value然后返回其引用。不同的是:当key不存在时,operator[]用默认value与key构造键值对然后插入,返回该默认value,at()函数直接抛异常
// 使用map迭代器进行遍历
void test()
{
	map<int, char> m;
	// 范围for尽量使用&:避免深拷贝带来的不必要开销
	for (auto& e : m)
		cout << e.first << "-->" << e.second << endl;
}

multiset特点:

  1. multiset是按照特定顺序存储元素的容器,与set的区别是,multiset中的元素可以重复,set是中value是唯一的
  2. multiset的作用:可以对元素进行排序,默认升序
  3. multiset中在底层中存储的是的键值对,底层结构为二叉搜索树(红黑树)

multimap特点:

  1. 注意:multimap和map的唯一不同就是:map中的key是唯一的,而multimap中key是可以重复的
  2. multimap中没有重载operator[]操作

你可能感兴趣的:(【C++】关联式容器——map、set、multimap、multiset)