1. List 容器的基本概念

1. list 是一个双向链表容器,可高效的进行插入删除元素,他的原理在于每个元素都有两个指针来记录前后两个元素的地址,像火车车厢一样,list 中各个元素在物理存储单元上非连续,是通过指针相连在一起的。

2. 相较于vector的连续线性空间,list会显得复杂许多,他的好处是每次插入或者删除1个元素,就是配置或释放一个元素的空间。

3. list 不可以随机存取元素,所以不支持 at.(position)函数与[]操作符。可以对其迭代器执行++,但是不能这样操作迭代器:it + 3

4. list 采用动态内存分配,不会造成内存的浪费和溢出

5. 链表执行插入和删除操作十分方便,修改指针即可,不需要移动大量元素

2. list 构造函数

1 list<T> lstT;                  //list采用采用模板类实现,对象的默认构造形式
2 list(beg, end); //构造函数将[beg, end)区间中的元素拷贝给本身
3 list(n, elem); //构造函数将n个elem拷贝给本身
4 list(const list & lst); //拷贝构造函数

具体用法参考:STL——容器(List)List 的构造函数

3. list 的数据元素插入和删除操作

 1 push_back(elem);            //在容器尾部加入一个元素
2 pop_back(); //删除容器中最后一个元素
3 push_front(elem); //在容器开头插入一个元素
4 pop_front(); //从容器开头移除第一个元素
5 insert(pos, elem); //在pos位置插elem元素的拷贝,返回新数据的位置,是否有返回值是由编译器版本决定
6 insert(pos, n, elem); //在pos位置插入n个elem数据,返回新数据的位置,是否有返回值是由编译器版本决定
7 insert(pos, beg, end); //在pos位置插入[beg,end)区间的数据,返回新数据的位置,是否有返回值是由编译器版本决定
8 clear(); //移除容器的所有数据
9 erase(beg, end); //删除[beg,end)区间的数据,返回下一个数据的位置
10 erase(pos); //删除pos位置的数据,返回下一个数据的位置
11 remove(elem); //删除容器中所有与elem值匹配的元素

具体用法参考:STL——容器(List)List 的数据元素插入和删除操作

4. list 的迭代器

1 list.begin();        //返回容器中第一个元素的迭代器。
2 list.end(); //返回容器中最后一个元素之后的迭代器。
3 list.rbegin(); //返回容器中倒数第一个元素的迭代器。
4 list.rend(); //返回容器中倒数最后一个元素的后面的迭代器。
5 list.cbegin(); //返回容器中第一个元素的常量迭代器。
6 list.cend(); //返回容器中最后一个元素之后的常量迭代器。

具体用法参考:其他几个例子中均有迭代器的使用

5. list 的大小操作

1 size();                //返回容器中元素的个数
2 empty();    //判断容器是否为空
3 resize(num);   //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除
4 resize(num, elem); //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除

具体用法参考:STL——容器(List)list 的大小操作

6. list 的赋值操作

1 assign(beg, end);                        //将[beg, end)区间中的数据拷贝赋值给本身。
2 assign(n, elem); //将n个elem拷贝赋值给本身。
3 list & operator=(const list & lst); //重载等号操作符
4 swap(lst); //将lst与本身的元素互换。

具体用法参考:STL——容器(List)list 的赋值操作

7. list 数据的存取

1 front();      //返回第一个元素
2 back(); //返回最后一个元素

具体用法参考:STL——容器(List)list 数据的存取

8. list 翻转排序

1 reverse();            //反转链表,比如lst包含1,3,5元素,运行此方法后,lst就包含5,3,1元素
2 sort(); //list排序

具体用法参考:STL——容器(List)list 的反序排列

=====================================================================================================================

STL——容器(List)List 的概念的更多相关文章

  1. STL 容器的概念

    STL 容器的概念 在实际的开发过程中,数据结构本身的重要性不会逊于操作于数据结构的算法的重要性,当程序中存在着对时间要求很高的部分时,数据结构的选择就显得更加重要. 经典的数据结构数量有限,但是我们 ...

  2. STL - 容器共性机制研究

    C++模板是容器的概念. 理论提高:所有容器提供的都是值(value)语意,而非引用(reference)语意.容器执行插入元素的操作时,内部实施拷贝动作.所以STL容器内存储的元素必须能够被拷贝(必 ...

  3. 关于STL容器

    容器: 概念:如果把数据看做物体,容器就是放置这些物体的器物,因为其内部结构不同,数据摆放的方式不同,取用的方式也不同,我们把他们抽象成不同的模板类,使用时去实例化它 分类: 序列容器.关联容器.容器 ...

  4. 【STL容器学习】-关联容器与map的用法

    STL提供了4个关联容器:set.multiset.map和multimap.这些容器提供了通过keyword高速存储和訪问数据元素的能力.Set和map不同意有反复keyword,而multiset ...

  5. 史上最全的各种C++ STL容器全解析

    史上最全的C++ STL 容器大礼包 为什么\(C++\)比\(C\)更受人欢迎呢?除了\(C++\) 的编译令人感到更舒适,\(C++\)的标准模板库(\(STL\))也占了很重要的原因.当你还在用 ...

  6. 标准非STL容器 : bitset

    1. 概念 什么是"标准非STL容器"?标准非STL容器是指"可以认为它们是容器,但是他们并不满足STL容器的所有要求".前文提到的容器适配器stack.que ...

  7. STL容器

    啦啦啦,今天听啦高年级学长讲的STL容器啦,发现有好多东西还是有必要记载的,毕竟学长是身经百战的,他在参加各种比赛的时候积累的经验可不是一天两天就能学来的,那个可是炒鸡有价值的啊,啊啊啊啊啊 #inc ...

  8. c++ stl容器set成员函数介绍及set集合插入,遍历等用法举例

    c++ stl集合set介绍 c++ stl集合(Set)是一种包含已排序对象的关联容器.set/multiset会根据待定的排序准则,自动将元素排序.两者不同在于前者不允许元素重复,而后者允许. 1 ...

  9. STL容器删除元素的陷阱

    今天看Scott Meyers大师的stl的用法,看到了我前段时间犯的一个错误,发现我写的代码和他提到错误代码几乎一模一样,有关stl容器删除元素的问题,错误的代码如下:std::vector< ...

随机推荐

  1. Node.js 爬虫爬取电影信息

    Node.js 爬虫爬取电影信息 我的CSDN地址:https://blog.csdn.net/weixin_45580251/article/details/107669713 爬取的是1905电影 ...

  2. Vue 组件化开发之插槽

    插槽的作用 相信看过前一篇组件化开发后,你对组件化开发有了新的认识. 插槽是干什么的呢?它其实是配合组件一起使用的,让一个组件能够更加的灵活多变,如下图所示,你可以将组件当作一块电脑主板,将插槽当作主 ...

  3. java基本权限指南之:文件和共享目录的基本权限

    简介 java程序是跨平台的,可以运行在windows也可以运行在linux.但是平台不同,平台中的文件权限也是不同的.windows大家经常使用,并且是可视化的权限管理,这里就不多讲了. 本文主要讲 ...

  4. MindManager导出Word文档功能介绍

    Mindmanager思维导图软件作为一款能与Microsoft office软件无缝集成的思维导图软件,支持Word文档的快速导入与导出,并支持Word文档的目录生成.模板套用等,极大地方便了用户完 ...

  5. leetcode152. 乘积最大子序列

    给定一个整数数组 nums ,找出一个序列中乘积最大的连续子序列(该序列至少包含一个数).示例 1:输入: [2,3,-2,4]输出: 6解释: 子数组 [2,3] 有最大乘积 6.示例 2:输入: ...

  6. canvas 元素覆盖&穿透问题

    给网站添加canvas动态背景.完后发现有a标签无法点击,想到是canvas覆盖了(但有些是可以的).网上查找,有解决穿透的问题,但canvas的鼠标事件会无效.后发现是定位问题. canvas样式 ...

  7. P4771 八百标兵奔北坡

    观察题目中关于北边的定义,发现是以当前点为顶点,向上的倒三角(自己想想为什么). 然后就可以直接 DP 了,令 \(f_{i,j}\) 表示点 \(\left(i,j\right)\) 的答案. \[ ...

  8. Java反射说得透彻一些

    目录 一.反射机制是什么? 二.反射的具体使用 2.1 获取对象的包名以及类名 2.2 获取Class对象 2.3 getInstance()获取指定类型的实例化对象 2.4 通过构造函数对象实例化对 ...

  9. Snap Build Your Own Block修炼之道-添加自定义类别

    Snap Build Your Own Block自我修炼方法:1.所有的面向对象,其实是对面向过程的抽象过程而已: 2.面对别人的开源项目时,需要找准源头(即项目运行的起点,当然有的是没有的哈,没有 ...

  10. A:与指定数字相同的数的个数

    总时间限制:  1000ms 内存限制:  65536kB 描述 输出一个整数序列中与指定数字相同的数的个数. 输入 输入包含三行:第一行为N,表示整数序列的长度(N <= 100):第二行为N ...