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

相关推荐
代码中介商7 分钟前
B树:数据库索引的高效基石
数据结构·数据库
Cheng小攸22 分钟前
2.隐藏账户
windows
小糯米60126 分钟前
C语言 自定义类型:结构体 与 联合体
c语言·开发语言·数据结构
chengO_o1 小时前
AVL树详解与实现(C++)
数据结构·c++·avl树·平衡二叉搜索树
玉树临风ives1 小时前
atcoder ABC 458 题解
数据结构·c++·算法
AKA__Zas1 小时前
芝士算法 (双指针篇2.0)
java·数据结构·leetcode·学习方法
如竟没有火炬1 小时前
有序矩阵中第K小的元素
数据结构·线性代数·算法·leetcode·矩阵·深度优先
吃胖点儿1 小时前
RAG系统优化完整路径:从30%到90%准确率的工程实践
服务器·数据库·windows
磊 子2 小时前
AVL树的讲解
数据结构·算法
技术不好的崎鸣同学2 小时前
Windows 命令提示符(CMD)内容补缺&输入输出重定向及管道
运维·windows