2、容器的结构与分类,array容器的测试,vecotr容器的测试,以及其他顺序容器的一些细节

容器的结构与分类:

首先介绍一下顺序容器:

Array 是数组,确定了开始位置和结束位置,同时不能超出它的内存。

Vector 确定了开始位置,但可以一直向后添加新的空间去存放元素。

Deque 开始位置能够扩充并且结束位置也能够扩充

List 双向链表,相比于Forward-List占用的内存更大,因为一个元素对应两个指针。

Forward-List 单向列表,看下面的小图可知开始位置是确定的。

关联容器:(一般用于查找)

Set 中key和value是一样的,通过红黑树来编写。

Map 中有两个格子,一个用来存放key一个用来存放value。

值得注意的是,multi-代表key的值可以相同,而不添加multi前缀代表,每个元素的key是独一无二的。

无顺序容器:

无顺序容器实际是由哈希表组成,哈希表见下图

即每一个竖直的蓝色小框框都代表一个链表,可以连接许多元素。但是每个蓝色小框中的链表不能太长,太长不方便查找。

侯捷老师最后给出一张所有容器的关系图,如下图所示:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值