C++ list容器
一、前言
list容器,又称为双向链表容器,即该容器的底层是以双向链表的形式实现的,因此list容器中的元素可以分散存储在内存空间里,而不是必须存储在一整块连续的内存空间中。
list容器中各个元素的前后顺序是靠指针维系的,每个元素都有两个指针,分别指向它的前一个元素和后一个元素。第一个元素的前向指针总为 null,因为它前面没有元素;同样,尾部元素的后向指针也总为 null。
优点:可以在序列已知的任何位置快速插入或删除元素(时间复杂度为O(1))。并且在 list 容器中移动元素,也比其它容器的效率高。
缺点:不能通过下标访问元素,只能从容器中第一个元素或最后一个元素开始遍历容器,直到找到对应元素。
list 容器以模板类 list头文件中,并位于 std 命名空间中。使用时需包含头文件:
#include <list>
using namespace std;
二、初始化list容器
一共有5种方式创建list容器
- 创建空的list容器
std::list<int> listInt;
- 创建一个包含10个元素,默认值为0的list容器
std::list<int> listInt(10);
- 创建一个包含10个元素,初始值为5的list容器
std::list<int> listInt(10, 5);
- 将以初始化的list容器进行拷贝创建新的list容器,须保证新旧容器存储的元素类型一致
std::list<int> listInt2(listInt);
- 通过拷贝其他类型容器(或者普通数组)中指定区域内的元素,创建 list 容器
//拷贝普通数组,创建list容器
int a[] = { 1,2,3,4,5 };
std::list<int> listInt(a, a+5);
//拷贝其它类型的容器,创建 list 容器
std::array<int, 5> arrInt{ 11,12,13,14,15 };
std::list<int> listInt(arrInt.begin()+2, arr.end());
1、成员函数
这里不列举迭代器、添加和删除等相关的函数。
函数功能
2、实例
1)创建list容器
std::list<int> listInt;
listInt.push_back(31);
listInt.push_back(27);
listInt.push_back(29);
std::cout << " listInt size: " << listInt.size() << std::endl;
int i = 0;
std::list<int>::iterator listIter = listInt.begin();
for (; listIter != listInt.end(); listIter++)
{
std::cout << " listInt[" << i++ << "]=" << *listIter << std::endl;
}
listInt.sort();
i = 0;
listIter = listInt.begin();
for (; listIter != listInt.end(); listIter++)
{
std::cout << " sort listInt[" << i++ << "]=" << *listIter << std::endl;
}
int nFront = listInt.front();
int nBack = listInt.back();
std::cout << " listInt front: " << nFront << " back: " << nBack << std::endl;
std::list<int> listInt1{ 14,25,99 };
listInt1.sort();
listInt.merge(listInt1);
i = 0;
listIter = listInt.begin();
for (; listIter != listInt.end(); listIter++)
{
std::cout << " merge listInt[" << i++ << "]=" << *listIter << std::endl;
}
结果如下:
3.迭代器
具体的功能不再说明,可参考array容器中的说明。list容器的迭代器和之前的array、vector等最大的不同在于:它的迭代器类型为双向迭代器,而不再是随机访问迭代器。
假如p1,p2都是双向迭代器,那么
支持++p1、 p1++、 p1--、 p1++、 *p1、 p1==p2 以及 p1!=p2;
不支持p1[i]、p1-=i、 p1+=i、 p1+i 、p1-i、p1<p2、 p1>p2、 p1<=p2、 p1>=p2。
1、实例
1)、遍历list容器元素
i = 0;
listIter = listInt.begin();
for (; listIter != listInt.end(); listIter++)
{
std::cout << " sort listInt[" << i++ << "]=" << *listIter << std::endl;
}
其他的函数功能和vector等类似,不再说明使用方法
注意点:
1、list 容器不支持随机访问,未提供下标操作符 [] 和 at() 成员函数,也没有提供 data() 成员函数
2、 front() 和 back() 成员函数,可以分别获得 list 容器中第一个元素和最后一个元素的引用形式,必要时还能修改其值
3、若希望访问list容器其他位置的元素,只能通过list容器的迭代器,也可以通过迭代器对指定元素的值进行修改
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了