标准模板库STL——deque和list

这篇具有很好参考价值的文章主要介绍了标准模板库STL——deque和list。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

deque概述

deque属于顺序容器,称为双端队列容器

底层数据结构是动态二维数组,从整体上看,deque的内存不连续

初始数组第一维数量为2,必要时进行2倍扩容

每次第一维扩容后,原来数组第二维元素从新数组下标为OldSize/2的第一维开始存储

这样的存储方式使得前后都预留相同空间,方便支持deque首尾元素添加

数组第二维长度固定

deque相关操作

// deque相较于vector增加的相关操作有:push_front()和pop_front()

deque<int> deq;

// 1、添加
deq.push_back(10);
// (1)向末尾添加元素10,时间复杂度为O(1)
deq.push_front(20);
// (2)向首部添加元素20,时间复杂度为O(1)
deq.insert(it, 30);
// (3)向迭代器it处添加元素30,需要挪动元素和更新迭代器,时间复杂度为O(n)

// 2、删除
deq.pop_back();
// (1)删除末尾元素,时间复杂度为O(1)
deq.pop_front();
// (2)删除首部元素,时间复杂度为O(1)
deq.erase(it);
// (3)删除迭代器it处元素,需要挪动元素和更新迭代器,时间复杂度为O(n)

// 3、查询
// (1)使用迭代器遍历

辨析vector和deque

1、底层数据结构不同

vector底层是动态一维数组;

deque底层是动态二维数组

2、添加删除元素的时间复杂度不同

首部添加删除操作频繁,选择deque

3、内存使用效率不同

vector需要连续内存空间,内存使用效率低;

deque分块存储数据,不要求内存空间连续,内存使用效率高

4、在中间位置添加删除的效率不同

vector效率更高,deque效率更低

因为vector使用连续内存空间,方便挪动元素

而deque的内存空间不连续,不便挪动元素

list概述

list属于顺序容器,称为链表容器

底层数据结构是双向循环链表

list相关操作

// list相较于vector增加的相关操作有:push_front()和pop_front()

list<int> mylist;

// 1、添加
mylist.push_back(10);
// (1)向末尾添加元素10,时间复杂度为O(1)
mylist.push_front(20);
// (2)向首部添加元素20,时间复杂度为O(1)
mylist.insert(it, 30);
// (3)向迭代器it处添加元素30,需要更新迭代器,时间复杂度为O(1)
// 链表进行insert前,需要进行query查询
// 对于链表来说,query查询效率低

// 2、删除
mylist.pop_back();
// (1)删除末尾元素,时间复杂度为O(1)
mylist.pop_front();
// (2)删除首部元素,时间复杂度为O(1)
mylist.erase(it);
// (3)删除迭代器it处元素,需要更新迭代器,时间复杂度为O(1)

// 3、查询
// (1)使用迭代器遍历

辨析vector和list

1、底层数据结构不同

vector底层是动态一维数组;

list底层是双向循环链表

2、时间复杂度不同

vector:增加删除O(n)、查询O(n)、随机访问O(1)

list:增加删除O(1)、查询O(n)

增加删除操作频繁,选择list;

随机访问操作频繁,选择vector文章来源地址https://www.toymoban.com/news/detail-656740.html

到了这里,关于标准模板库STL——deque和list的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 0829|C++day7 auto、lambda、C++数据类型转换、C++标准模板库(STL)、list、文件操作

        封装一个学生的类,定义一个学生这样类的vector容器, 里面存放学生对象(至少3个) 再把该容器中的对象,保存到文件中。 再把这些学生从文件中读取出来,放入另一个容器中并且遍历输出该容器里的学生。

    2024年02月10日
    浏览(31)
  • 标准模板库STL——迭代器

    目录 四类迭代器概述 代码段 普通正向迭代器 普通反向迭代器 常量正向迭代器 常量反向迭代器 四类迭代器 普通正向迭代器 iterator 常量正向迭代器 const_iterator 普通反向迭代器 reverse_iterator 常量反向迭代器 const_reverse_iterator 解释说明 普通表示可以读元素,也可以写元素; 常量

    2024年02月12日
    浏览(25)
  • 58.C++ STL标准模板库 STL概述 STL三大组件

            长久以来,软件界⼀直希望建⽴⼀种可重复利⽤的东⻄,以及⼀种得以制造出”可重复运⽤的东⻄”的⽅法,让程序员的⼼⾎不⽌于随时间的迁移,⼈事异动⽽烟消云散,从函(functions),类别(classes),函数库(functionlibraries),类别库(class libraries)、各种组件,从模块化设计

    2024年02月12日
    浏览(31)
  • 15 标准模板库STL之简介

    STL         STL,即标准模板库,英文全称为Standard Template Library。STL最初由惠普实验室开发,于1998年被定为国际标准,正式成为C++标准库中不可或缺的重要组成部分,也是C++标准库中极具革命性的一部分。STL包含了很多在计算机科学领域常用的基本数据结构和基本算法,为

    2023年04月19日
    浏览(31)
  • 16 标准模板库STL之vector

    基础知识         1、vector和数组有点类似,但它比数组更好用。一般来说,数组的长度是不能动态拓展的,因此就需要考虑长度到底多大合适。长度不能过大,否则浪费内存;也不能过小,否则内存不够。vector正好弥补了这个缺陷,相当于一个可以自动改变数组长度的动

    2023年04月17日
    浏览(39)
  • 21 标准模板库STL之string

    概述         从严格意义上来说,string并不是STL中的容器,但它与容器有很多类似的接口和操作。string是STL中的一个类,对char *或char[]类型的字符串进行了封装。使用string后,不需要再考虑内存是否足够、内存是否未释放、内存越界等问题。除此之外,string还提供了一系

    2024年02月04日
    浏览(40)
  • 25 标准模板库STL之算法2

    搜索算法         常用的搜索算法可参看下表。 函数名 算法描述 search 搜索迭代器区间中与另一个迭代器区间所有元素匹配的第一次的位置 search_n 搜索迭代器区间中与若干个相同元素匹配的第一次的位置 binary_search 以二分法在有序序列中查找指定值,找到返回true,否则

    2024年02月06日
    浏览(25)
  • 24 标准模板库STL之算法1

    概述         算法是STL中用来处理容器中数据的一系列模板函数,可以对数据集合进行查找、排序、拷贝等操作。通过使用迭代器,算法可以运用在任意容器之上,做到与操作的数据的类型和结构无关。         STL算法博大精深,涵盖范围非常之广,一共提供了大约

    2024年02月05日
    浏览(25)
  • 15 标准模板库STL之容器1

    基础知识         1、vector和数组有点类似,但它比数组更好用。一般来说,数组的长度是不能动态拓展的,因此就需要考虑长度到底多大合适。长度不能过大,否则浪费内存;也不能过小,否则内存不够。vector正好弥补了这个缺陷,相当于一个可以自动改变数组长度的动

    2023年04月12日
    浏览(30)
  • 23 标准模板库STL之迭代器

    概述         迭代器作为STL中的三大组件之一,是容器和算法的粘合剂。迭代器提供了访问容器中元素的方法,每一种容器都提供了自己的迭代器,而这些迭代器向外界隐藏了容器的内部结构。算法使用迭代器访问容器中的元素,不需要关心容器的内部结构。        

    2024年02月05日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包