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存放内存

相关推荐
深耕AI1 小时前
使用Windows创建一个MFC应用【带界面】
c++·windows·mfc
Bug退退退1231 小时前
LeetCode18.四数之和
java·数据结构·算法
凭栏落花侧1 小时前
Windows性能监控与调优:让电脑运行如飞
windows
一个不喜欢and不会代码的码农1 小时前
设计一个尽可能高效的划分算法,满足|n1-n2|最小且|S1-S2|最大
数据结构·算法·排序算法
hanruanjian2 小时前
CDR2024官方学习版安装包+升级补丁包+注册机
android·windows·学习·microsoft·macos·idm
CharlesC++2 小时前
一元n次多项式加法【数据结构-链表】
数据结构·链表
-Turbo2 小时前
将一个单向链表插入到一个循环链表尾部
数据结构·链表
“抚琴”的人2 小时前
C#操作SqlServer数据库事务
数据库·windows·sql·sqlserver·c#
竹竹零2 小时前
JAVA队列
java·开发语言·数据结构·个人开发
代码雕刻家2 小时前
数据结构-5.4.二叉树的性质
数据结构·算法