HR常问到的vector和list以及deque的区别和各自优缺点

vector和list以及deque的区别
各自优缺点:

vector:

优点:
随机存取,即[]操作和vector.at()
动态操作,push_back()与pop_back()
自动调整内存,节省空间
缺点:
实现插入与删除操作效率低
只能在尾部插入与删除,在头部插入与删除消耗时间规模与容器大小成正比。
当动态添加的数据超过默认内存大小时,要进行整体的重新分配,拷贝与释放。

list:

优点:
内存不连续
动态操作,插入与删除效率高
可在两端进行pop,push
缺点:
不能随机访问
相对于vector占用内存多

deque:

优点:
随机访问,即[]操作和deque.at()
插入与删除方便
可在双端进行pop,push
缺点:
占用内存多。

综上所述三者的却别如下:

相同点:

 三者都能实现resize()来重新调整容器的大小。

不同点:

1)vector能实现随即存取,即[]操作,而list不能,deque是二者的结合体,也能够实现索引操作[],但效率没有vector高。
2)vector适合在文件的末尾实现删除元素的操作pop_back()与插入操作push_back(),在中间时效率非常低下。而
list可以在容器的任何位置实现插入与删除操作。
原因:vector的元素地址连续,如果在中间插入与删除操作,可能会导致原来的内存地址不足以存储当前的元素,需要重
新分配内存地址,这就需要将原来的所有元素拷贝到新内存,释放旧的内存地址等操作,操作代价高昂。而list元素内存地
址不连续,用指针操作,其本身是一个双向链表,它的高效率体现在插入,删除以及排序等移动大量元素的操作。

选择容器类型的准则:

1)如果需要随机访问一个容器,vector比list好
2)如果经常需要插入或删除容器元素,list比vector好
3)如果既要随机存取,又要关心两端数据的插入与删除,则选择deque
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

N1314N

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值