list和vector的区别

1>list可以按值删除

vector和deque没有给定的函数,需要find();和erase();一起使用才能做到

2>list删除元素会释放空间,vector不会

3>list是双向迭代器,vector是随机迭代器

4>list内部排序是指针指向的更改,vector涉及对象的创建和销毁

5>vector改变元素,导致迭代器失效

deque删除的时候不会导致迭代器失效(非迭代器位置),插入会导致迭代器失效

list删除元素导致当前迭代器失效,不影响其他迭代器

6>vector是连续存储容器,动态数组

list是动态双向链表

7>vector连续空间,不容易产生内部碎片

list节点不连续,容易造成内部碎片,空间利用率低

8>vector访问具有局部性,存放高速缓存

list存放内存

相关推荐
Morwit25 分钟前
*【力扣hot100】 215. 数组中的第K个最大元素
数据结构·c++·算法·leetcode·职场和发展
ab15151727 分钟前
3.20二刷基础121、127,完成进阶61、62
数据结构·算法·排序算法
I_LPL28 分钟前
day58 代码随想录算法训练营 图论专题11
数据结构·算法·图论
小比特_蓝光35 分钟前
算法篇1-----双指针
数据结构·算法
lihao lihao43 分钟前
二分查找
java·数据结构·算法
WolfGang0073211 小时前
代码随想录算法训练营 Day15 | 二叉树 part05
数据结构·算法
包饭厅咸鱼1 小时前
小龙虾openclaw----Windows+Wsl+Docker 安装openclaw 并接入飞书
windows·docker·openclaw·小龙虾
※※冰馨※※1 小时前
【QT】TortoiseGit配 SSH 克隆 Codeup
开发语言·c++·windows
LDR0061 小时前
如何使用OpenClaw提高工作效率?
数据结构·算法