c++顺序容器

1.一个容器就是一些特定类型的对象,顺序容器为程序员提供了控制元素储存和访问顺序的能力,这种顺序依赖于元素加入容器的位置,与无序、关联容器相对

2.顺序容器提供了快速顺序访问元素的能力,但是也有性能折中:添加或删除元素;非顺序访问容器中元素

3.vector和string将元素保存在连续的内存空间中,因此通过下标计算地址是非常快速的,但是在中间位置添加或删除元素会非常耗时(插入或删除后需要移动其后的所有元素来保持连续)

4.list和forward_list分别是双向链表和链表,分别支持双向访问和单向访问。在链表中任何位置插入、删除操作速度都很快,作为代价,不支持随机访问,为了访问一个元素只能历遍整个容器,而且额外的内存开销也很大

5.array是固定大小的数组,支持随机访问,不能添加或删除元素,与内置数组相比,array更加安全更容易使用

6.deque是双向队列,支持快速随机访问,在两端添加或删除元素都是很快的,但是在中间位置添加或删除元素的代价可能很高

7.如果程序只有在读取输入时需要在容器中间位置插入元素,随后需要随机访问元素,可以在输入阶段使用list,输入完成将list拷贝到vector中

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值