c++11 List 容器

List简介

list是一个双向链表容器
       可高效地进行插入删除元素。 
       list不可以随机存取元素,所以不支持at(pos)函数与[]操作符。 
       #include <list>

list对象的默认构造

list采用采用模板类实现
         对象的默认构造形式:
         list<T> lstT

示例:
         list<int> lstInt; //定义一个存放int的list容器。
         list<float> lstFloat; //定义一个存放float的list容器。
         list<string> lstString; //定义一个存放string的list容器。
         ...
         //尖括号内还可以设置指针类型或自定义类型。

list对象的带参数构造

理论知识:

list(beg,end)
构造函数将[beg, end)区间中的元素拷贝给本身。 注意该区间是左闭右开的区间。

list(n,elem)
构造函数将n个elem拷贝给本身。

list(n)
创建n个元素的容器,初始值为0

list(const list &lst)
拷贝构造函数。

示例:

list<int> lstIntA;
lstIntA.push_back(1);
lstIntA.push_back(3);
lstIntA.push_back(5);
lstIntA.push_back(7);
lstIntA.push_back(9);
list<int> lstIntB(lstIntA.begin(),lstIntA.end()); //1 3 5 7 9
list<int> lstIntC(5,8); //8 8 8 8 8
list<int> lstIntD(lstIntA); //1 3 5 7 9

list头尾的添加移除操作

理论知识:

list.push_back(elem)
在容器尾部加入一个元素

list.pop_back()
删除容器中最后一个元素

list.push_front(elem)
在容器开头插入一个元素

list.pop_front()
从容器开头移除第一个元素

示例:

list<int> lstInt;
lstInt.push_back(1);
lstInt.push_back(3);
lstInt.push_back(5);
lstInt.push_back(7);
lstInt.push_back(9);
lstInt.pop_front();
lstInt.pop_front();
lstInt.push_front(11);
lstInt.push_front(13);
lstInt.pop_back();
lstInt.pop_back();

// lstInt {13,11,5}

list的数据存取

理论知识:

list.front();
返回第一个元素的引用。

list.back();
返回最后一个元素的引用。

示例:

list<int> lstInt;
lstInt.push_back(1);
lstInt.push_back(3);
lstInt.push_back(5);
lstInt.push_back(7);
lstInt.push_back(9);
int iFront = lstInt.front(); //1
int iBack = lstInt.back(); //9
lstInt.front() = 11; //11
lstInt.back() = 19; //19

list的大小

理论知识:

ls.size()
返回容器中元素的个数

ls.empty()
判断容器是否为空

ls.resize(num)
重新指定容器的长度为num,若容器变长,则 以默认值填充新位置。如果容器变短,则末尾 超出容器长度的元素被删除。

ls.resize(num, elem)
重新指定容器的长度为num,若容器变长 ,则以elem值填充新位置。如果容器变短 ,则末尾超出容器长度的元素被删除。

示例:
list<int> lstIntA;
lstIntA.push_back(1);
lstIntA.push_back(3);
lstIntA.push_back(5);
if (!lstIntA.empty())
{
        int iSize = lstIntA.size(); //3
        lstIntA.resize(5); //1 3 5 0 0
        lstIntA.resize(7,1); //1 3 5 0 0 1 1
        lstIntA.resize(2); //1 3
}

list与迭代器

理论知识:

list.begin()
返回容器中第一个元素的迭代器。

list.end()
返回容器中最后一个元素之后的迭代器。

list.rbegin()
返回容器中倒数第一个元素的迭代器。

list.rend()
返回容器中倒数最后一个元素的后面的迭代器。

示例:

list<int> lstInt;
lstInt.push_back(1);
lstInt.push_back(3);
lstInt.push_back(5);
lstInt.push_back(7);
lstInt.push_back(9);
for (list<int>::iterator it=lstInt.begin();
it!=lstInt.end(); ++it)
{
      cout << *it; cout << " ";
}
for (list<int>::reverse_iterator rit=lstInt.rbegin();
rit!=lstInt.rend(); ++rit)
{
      cout << *rit;
      cout << " ";
}

list的赋值

理论知识:

list.assign(beg,end)
将[beg, end)区间中的数据拷贝赋值给本身。注意该区间是左闭右开的区间。

list.assign(n,elem)
将n个elem拷贝赋值给本身。

list& operator=(const list &lst)
重载等号操作符

list.swap(lst)
将lst与本身的元素互换。

示例:

list<int> lstIntA,lstIntB,lstIntC,lstIntD;
lstIntA.push_back(1);
lstIntA.push_back(3);
lstIntA.push_back(5);
lstIntA.push_back(7);
lstIntA.push_back(9);
lstIntB.assign(lstIntA.begin(),lstIntA.end()); //1 3 5 7 9
lstIntC.assign(5,8); //8 8 8 8 8
lstIntD = lstIntA; //1 3 5 7 9
lstIntC.swap(lstIntD); //互换

list的插入

理论知识:

ls.insert(pos,elem)
在pos位置插入一个elem元素的拷贝,返回新数据的位置。

ls.insert(pos,n,elem)
在pos位置插入n个elem数据,无返回值。

ls.insert(pos,beg,end)
在pos位置插入[beg,end)区间的数据,无返回值。

示例:

list<int> lstA;
list<int> lstB;

lstA.push_back(1);
lstA.push_back(3);
lstA.push_back(5);
lstA.push_back(7);
lstA.push_back(9);

lstB.push_back(2);
lstB.push_back(4);
lstB.push_back(6);
lstB.push_back(8);

lstA.insert(lstA.begin(), 11);    //{11, 1, 3, 5, 7, 9}
lstA.insert(++lstA.begin(),2,33);    //{11,33,33,1,3,5,7,9}
lstA.insert(lstA.begin() , lstB.begin() , lstB.end() );  //{2,4,6,8,11,33,33,1,3,5,7,9}

list的删除

理论知识:

ls.clear()
移除容器的所有数据

ls.erase(beg,end)
删除[beg,end)区间的数据,返回下一个数据的位置。

ls.erase(pos)
删除pos位置的数据,返回下一个数据的位置。

ls.remove(elem)
删除容器中所有与elem值匹配的元素。

示例:

删除区间内的元素
lstInt是用list<int>声明的容器,现已包含按顺序的1,3,5,6,9元素。

list<int>::iterator itBegin=lstInt.begin();
++ itBegin;
list<int>::iterator itEnd=lstInt.begin();
++ itEnd;
++ itEnd;
++ itEnd;
lstInt.erase(itBegin,itEnd);
//此时容器lstInt包含按顺序的1,6,9三个元素。

假设 lstInt 包含1,3,2,3,3,3,4,3,5,3,删除容器中等于3的元素的方法一
for(list<int>::iterator it=lstInt.being(); it!=lstInt.end(); ) //小括号里不需写 ++it
{
        if(*it == 3)
        {
                it = lstInt.erase(it); //以迭代器为参数,删除元素3,并把数据删除后的下一个元素位置返回给迭代器。
                //此时,不执行 ++it;
        }
        else
        {
                ++it;
        }
}

删除容器中等于3的元素的方法二
lstInt.remove(3);

删除lstInt的所有元素
lstInt.clear(); //容器为空

list的反序排列

理论知识:

lst.reverse() 反转链表,
比如lst包含1,3,5元素,运行此方法后,lst就包含5,3,1元素。

示例:

list<int> lstA;
lstA.push_back(1);
lstA.push_back(3);
lstA.push_back(5);
lstA.push_back(7);
lstA.push_back(9);
lstA.reverse(); //9 7 5 3 1

c++11 List 容器的更多相关文章

  1. c++11——改进容器性能

    使用emplace_back就地构造 emplace_back能就地通过参数构造对象,不需要拷贝或者移动内存,相比push_back能更好的避免内存的拷贝和移动,使得容器插入元素的性能得到进一步提升. ...

  2. C++11新增容器以及元组

    上次说了C++11的部分新特性,这里我们来说说新增的容器. unordered_map unordered_set unordered_multimap unordered_multiset arra ...

  3. JAVA编程思想(第四版)学习笔记----11.4 容器的打印

    import static java.lang.System.out; import java.util.ArrayList; import java.util.Collection; import ...

  4. c++11の顺序容器

      容器是一种容纳特定类型对象的集合.C++的容器可以分为两类:顺序容器和关联容器.顺序容器的元素排列和元素值大小无关,而是由元素添加到容器中的次序决定的.标准库定义了三种顺序容器的类型:vector ...

  5. c++11の关联容器

    一.关联容器 C++的容器类型可以分为顺序容器和关联容器两大类.对于关联容器,主要有map和set,对于这两种,根据不同的维度,衍生出了8种容器 map                        ...

  6. 11.string容器

    #include <iostream> //string的本质也是容器 #include <string> #include <cstdlib> using nam ...

  7. 跟我一起学STL(2)——vector容器详解

    一.引言 在上一个专题中,我们介绍了STL中的六大组件,其中容器组件是大多数人经常使用的,因为STL容器是把运用最广的数据结构实现出来,所以我们写应用程序时运用的比较多.然而容器又可以序列式容器和关联 ...

  8. STL之容器基本操作

    容器类 STL Container Header Applications vector <vector> 直接访问任意元素,快速插入.删除尾部元素 deque <deque> ...

  9. Java编程思想(11~17)

    [注:此博客旨在从<Java编程思想>这本书的目录结构上来检验自己的Java基础知识,只为笔记之用] 第十一章 持有对象 11.1 泛型和类型安全的容器>eg: List<St ...

随机推荐

  1. axios的简单使用

    axios是一个通用的ajax请求库,vue 2.0以后,推荐使用axios Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中. 使用: 1.下载安装 n ...

  2. JAVA的关键特性

    Java团队对设计Java时的关键考虑因素进行了总结,关键特性包含以下列表: 简单性 安全性 可移植性 面向对象 健壮性 多线程 体系结构中立 解释执行 高性能 分布式 动态性 简单性 Java的设计 ...

  3. 将禅道部署到腾讯云linux 上

    部署环境 :linux(腾讯云),用到了 xshell   FileZilla 使用禅道集成环境lampp直接部署 1.首先下载 lampp j集成环境包.https://sourceforge.ne ...

  4. i++ i+=1 i=i+1 汇编代码效率比较

    结论:一样.编译器和编译器之间可能有点区别但是程序不会变. 0x00 一直不清楚到底是因为懒还是真的为了效率,要把" i = i + 1 "写成" i++ "或 ...

  5. 阿里云解析记录应对家里动态IP

    <?php #需要配置的项 define('ACCESSKEYID',''); #阿里云用户密钥ID 获取方法 https://help.aliyun.com/knowledge_detail/ ...

  6. java浮点数存储

    转自: [解惑]剖析float型的内存存储和精度丢失问题 1.小数的二进制表示问题 首先我们要搞清楚下面两个问题: (1)  十进制整数如何转化为二进制数 算法很简单.举个例子,11表示成二进制数: ...

  7. 互评Beta版本——杨老师粉丝群——Pinball

    互评beta版本    杨老师粉丝群——<PinBall> 一.基于NABCD评论作品,及改进建议 1.根据(不限于)NABCD评论作品的选题 (1)N(Need,需求) 随着年龄的增长, ...

  8. Beta阶段版本控制报告

    版本控制代码及文档要求 在coding.net版本控制; 公开项目,教师.专家.其他同学可以不注册源代码.在此公布git地址. 报告beta阶段2周中,项目的版本控制情况,不包括未在coding.ne ...

  9. No.10_分数分配

    C#队一共有7名成员,因此团队贡献分一共350分. 分配方式应当反映绝大部分组员的真实贡献情况,即由贡献决定分数. 另外保证一定的奖惩措施,充分调动组员的积极性,鞭策团队向前迈进. 对于团队贡献分数的 ...

  10. 实验1:java开发环境的熟悉

    一.实验内容 1. 使用JDK编译.运行简单的Java程序 2.使用Eclipse 编辑.编译.运行.调试Java程序 3.实现四则运算并进行测试. 二.实验知识点 1. JVM.JRE.JDK的安装 ...