摘自:数组,vector,map,list,queue区别
摘自:C++面试题之list和vector的区别
C#中Vector< T > 的T 不能是可以为Null的对象。
List< T >的T 可以是 能为Null的对象。
1.vector数据结构
vector和动态数组类似,拥有一段连续的内存空间,并且起始地址不变。因此能高效的进行随机存取,时间复杂度为o(1);但因为内存空间是连续的,所以在进行插入和删除操作时,会造成内存块的拷贝,时间复杂度为o(n)。
2.list数据结构
list是由双向链表实现的,因此内存空间是不连续的。只能通过指针访问数据,所以list的随机存取非常没有效率,时间复杂度为o(n);但由于链表的特点,能高效地进行插入和删除。
下面列举了一些选择容器类型的法则:
- 如果程序要求随机访问元素,则应使用 vector 或 deque 容器。
- 如果程序必须在容器的中间位置插入或删除元素,则应采用 list 容器。
- 如果程序不是在容器的中间位置,而是在容器首部或尾部插入或删除元素,则应采用 deque 容器。
- 如果只需在读取输入时在容器的中间位置插入元素,然后需要随机访问元素,则可考虑在输入时将元素读入到一个 list 容器,接着对此容器重新排序,使其适合顺序访问,然后将排序后的 list 容器复制到一个 vector容器。