STL之树形结构的关联式容器

STL中有很多的容器比如说序列是容器和关联式容器,经常见到的容器有这些:vector,list,deque,forward_lise等,这几个容器通常称为序列式容器,因为其底层为线性序列的数据结构,里面存储的是元素本身。

什么是关联是容器?

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

键值对:用来表示具有一一对应关系的一种结构,该结构中一般只包含两个成员变量key和value,key代表键值,value代表与之相对应的信息。

树形结构关联式容器主要有四种:map,set,multimap,multiset,但常用的只有map,和set两种。

其共同点是:使用平衡搜索树(即红黑树)作为其底层结构,容器中的元素是一个有序的序列。

map的简介:

1. map是关联容器,它按照特定的次序(按照key来比较)存储由键值key和值value组合而成的元素。

2. map中,键值key通常用于排序和惟一地标识元素,而值value中存储与此键值key关联的内容。键值

key和值value的类型可能不同,并且在map的内部,keyvalue通过成员类型value_type绑定在一起,

为其取别名称为pair:

typedef pair value_type;

3. 在内部,map中的元素总是按照键值key进行比较排序的。

4. map中通过键值访问单个元素的速度通常比unordered_map容器慢,但map允许根据顺序对元素进行

直接迭代(即对map中的元素进行迭代时,可以得到一个有序的序列)

5. map支持下标访问符,即在[]中放入key,就可以找到与key对应的value

6. map通常被实现为二叉搜索树(更准确的说:平衡二叉搜索树(红黑树))

map的总结:

1. map中的的元素是键值对

2. map中的key是唯一的,并且不能修改

3. 默认按照小于的方式对key进行比较

4. map中的元素如果用迭代器去遍历,可以得到一个有序的序列

5. map的底层为平衡搜索树(红黑树),查找效率比较高

6. 支持[]操作符,operator[]中实际进行插入查找。

set的简介:

1. set是按照一定次序存储元素的容器

2. set中,元素的value也标识它(value就是key,类型为T),并且每个value必须是唯一的。set中的元素

不能在容器中修改(元素总是const),但是可以从容器中插入或删除它们。

3. 在内部,set中的元素总是按照其内部比较对象(类型比较)所指示的特定严格弱排序准则进行排序。

4. set容器通过key访问单个元素的速度通常比unordered_set容器慢,但它们允许根据顺序对子集进行直

接迭代。

5. set在底层是用二叉搜索树(红黑树)实现的。

 

 


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值