list和vector的区别
vector和动态数组类似,拥有一段连续的内存空间,能高效的进行随机存取,时间复杂度为o(1);但在进行插入和删除操作时,会造成内存块的拷贝,时间复杂度为o(n)。
2.list数据结构
list是由双向链表实现的,内存空间是不连续的。访问数据时间复杂度为o(n);但能高效地进行插入和删除。
已知元素是连续存储的,当我们在容器内添加一个元素时,想想会发生什么事情:
vector: 如果容器中已经没有空间容纳新的元素,此时,由于元素必须连续存储以便索引访问,所以不能在内存中随便找个地方存储这个新元素。于是,vector 必须重新分配存储空间,用来存放原来的元素以及新添加的元素:存放在旧存储空间中的元素被复制到新存储空间里,接着插入新元素,最后撤销旧的存储空间。
在 list 容器中添加一个元素,标准库只需创建一个新元素,然后将该新元素连接在已存在的链表中,不需要重新分配存储空间,也不必复制任何已存在的元素。
vector所分配的额外内存容量的确切数目因库的实现不同而不同。事实上,其性能非常好,因此在实际应用中,比起 list 和deque 容器,vector 的增长效率通常会更高。
如果程序既需要随机访问又必须在容器的中间位置插入或删除元素,那应该怎么办呢?
此时,选择何种容器取决于下面两种操作付出的相对代价:随机访问 list 容器元素的代价,以及在 vector 或 deque 容器中插入/删除元素时复制元素的代价。通常来说,应用中占优势的操作(程序中更多使用的是访问操作还是插入/删除操作)将决定应该什么类型的容器。