前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >STL学习笔记(8)常用容器 list

STL学习笔记(8)常用容器 list

作者头像
轻舞飞扬SR
发布2021-04-13 15:01:46
4110
发布2021-04-13 15:01:46
举报
文章被收录于专栏:Visual CodexVisual Codex

list 容器基本概念

链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成。每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域。 相较于 vector 的连续线性空间,list 就显得负责许多,它的好处是每次插入或者删除一个元素,就是配置或者释放一个元素的空间。因此,list 对于空间的运用有绝对的精准,一点也不浪费。而且,对于任何位置的元素插入或元素的移除,list 永远是常数时间。

list 和 vector 是两个最常被使用的容器。

在这里插入图片描述
在这里插入图片描述
  • list 容器是一个双向链表。
  • 采用动态存储分配,不会造成内存浪费和溢出。
  • 链表执行插入和删除操作十分方便,修改指针即可,不需要移动大量元素。
  • 链表灵活,但是空间和时间额外耗费较大

list 容器的迭代器

List 容器不能像 vector 一样以普通指针作为迭代器,因为其节点不能保证在同一块连续的内存空间上。list 迭代器必须有能力指向 list 的节点,并有能力进行正确的递增、递减、取值、成员存取操作。所谓“list 正确的递增,递减、 取值、成员取用”是指:递增时指向下一个节点,递减时指向上一个节点,取值时取的是节点的数据值,成员取用时取的是节点的成员。 由于 list 是一个双向链表,迭代器必须能够具备前移、后移的能力,所以 list 容器提供的是 Bidirectional Iterators. List 有一个重要的性质,插入操作和删除操作都不会造成原有 list 迭代器的失效。这在 vector 是不成立的,因为 vector 的插入操作可能造成记忆体重新配置,导致原有的迭代器全部失效,甚至 List 元素的删除,也只有被删除的那个元素的迭代器失效,其他迭代器不受任何影响。

list 常用操作

1. list 构造函数
代码语言:javascript
复制
list<T> lstT;//list 采用采用模板类实现,对象的默认构造形式: 
list(beg,end);//构造函数将[beg, end)区间中的元素拷贝给本身。 
list(n,elem);//构造函数将 n 个 elem 拷贝给本身。 
list(const list &lst);//拷贝构造函数。
2. list 数据元素插入和删除操作
代码语言:javascript
复制
push_back(elem);//在容器尾部加入一个元素 
pop_back();//删除容器中最后一个元素 
push_front(elem);//在容器开头插入一个元素 
pop_front();//从容器开头移除第一个元素 
insert(pos,elem);//在 pos 位置插 elem 元素的拷贝,返回新数据的位置。 
insert(pos,n,elem);//在 pos 位置插入 n 个 elem 数据,无返回值。 
insert(pos,beg,end);//在 pos 位置插入[beg,end)区间的数据,无返回值。 
clear();//移除容器的所有数据 
erase(beg,end);//删除[beg,end)区间的数据,返回下一个数据的位置。 
erase(pos);//删除 pos 位置的数据,返回下一个数据的位置。 
remove(elem);//删除容器中所有与 elem 值匹配的元素。
3. list 大小操作
代码语言:javascript
复制
size();//返回容器中元素的个数 
empty();//判断容器是否为空 
resize(num);//重新指定容器的长度为 num, 若容器变长,则以默认值填充新位置。 如果容器变短,则末尾超出容器长度的元素被删除。 
resize(num, elem);//重新指定容器的长度为 num, 若容器变长,则以 elem 值填充新位置。 如果容器变短,则末尾超出容器长度的元素被删除。 
4. list 赋值操作
代码语言:javascript
复制
assign(beg, end);//将[beg, end)区间中的数据拷贝赋值给本身。 
assign(n, elem);//将 n 个 elem 拷贝赋值给本身。 
list& operator=(const list &lst);//重载等号操作符 
swap(lst);//将 lst 与本身的元素互换。 
5. list 数据的存取
代码语言:javascript
复制
front();//返回第一个元素。 
back();//返回最后一个元素。 
6. list 反转排序
代码语言:javascript
复制
reverse();//反转链表,比如 lst 包含 1,3,5 元素,运行此方法后,lst 就包含 5,3,1 元素。 
sort(); //list 排序

参考《千锋教育》

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-04-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • list 容器基本概念
  • list 容器的迭代器
  • list 常用操作
    • 1. list 构造函数
      • 2. list 数据元素插入和删除操作
        • 3. list 大小操作
          • 4. list 赋值操作
            • 5. list 数据的存取
              • 6. list 反转排序
              相关产品与服务
              容器服务
              腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档