C++修炼之路之list--C++中的双向循环链表

目录

前言

一:正式之前先回顾数据结构中的双向循环链表

二:list的简介

三:STL中list常用接口函数的介绍及使用

1.构造函数接口

[2.list迭代器 +范围for](#2.list迭代器 +范围for)

3.数据的修改接口函数

4.list容量操作函数

5.list的迭代器失效

6.演示代码和测试用例链接

接下来的日子会顺顺利利,万事胜意,生活明朗-----------林辞忧

前言

list简单来说就是数据结构中的双向循环链表,作为链表中的顶级结构,双向循环链表的任意位置插入删除数据效率高,而且不用像单链表那样分情况来讨论插入删除的情况,在C++中经过封装变为了常用的list,接下来我们就将介绍它

一:正式之前先回顾数据结构中的双向循环链表

对于双向循环链表的结构与使用可以参考本篇文章

https://blog.csdn.net/Miwll/article/details/136593441?spm=1001.2014.3001.5501

了解双向循环链表的结构,方便模拟实现list

二:list的简介

对于list在官方文档中的介绍为

https://cplusplus.com/reference/list/list/?kw=list

1.list是可以在常熟时间范围内在任意位置进行插入和删除的容器,并且支持前后双向迭代遍历数据

2.对比与其他的容器,list是不支持任意位置的随机访问的,必须从已知位置开始往后遍历寻找

三:STL中list常用接口函数的介绍及使用

1.构造函数接口

对于构造常规的就是这几种,只需多使用便没问题

list<int> lt1;//无参构造
for (auto e : lt1)
{
	cout << e << " ";
}
cout << endl;

list<int> lt2(10,2);//n个val来构造
for (auto e : lt2)
{
	cout << e << " ";
}
cout << endl;

list<int> lt3(lt2);//拷贝构造
for (auto e : lt3)
{
	cout << e << " ";
}
cout << endl;

list<int>lt4(lt3.begin(), lt3.end());//用一段迭代器来构造
for (auto e : lt4)
{
	cout << e << " ";
}
cout << endl;

2.list迭代器 +范围for

对于此处的迭代器我们可以理解为一个指针,指向list中的某个节点

常常的有普通迭代器和const对象用的const迭代器,正向反向迭代器

对于list中的迭代器是比较复杂的,在模拟实现中会详细介绍的

list<int> lt2(10, 2);//n个val来构造
list<int>::iterator it = lt2.begin();//迭代器
while (it != lt2.end())
{
	cout << *it << " ";
	++it;
}
cout << endl;

for (auto e : lt2)
{
	cout << e << " ";
}
cout << endl;

list<int>::reverse_iterator rit = lt2.rbegin();//反向迭代器
while (rit != lt2.rend())
{
	cout << *rit << " ";
	++rit;
}
cout << endl;

3.数据的修改接口函数

对于insert和erase操作使用的是迭代器位置来插入和删除,剩余的操作便是常见的

list<int> lt1;
lt1.push_back(1);
lt1.push_back(2);
lt1.push_back(3);
lt1.push_back(4);
lt1.push_back(5);
for (auto e : lt1)
{
	cout << e << " ";
}
cout << endl;

lt1.push_front(10);//前插10
for (auto e : lt1)
{
	cout << e << " ";
}
cout << endl;

lt1.insert(lt1.begin(),10);//头插10
for (auto e : lt1)
{
	cout << e << " ";
}
cout << endl;

lt1.erase(lt1.begin());//头删
for (auto e : lt1)
{
	cout << e << " ";
}
cout << endl;
lt1.clear();//清空数据

4.list容量操作函数

对于list是不需要添加resize和reserve这下扩容接口函数 ,是直接就可以创建节点来操作的

cout << lt2.size() << endl;
cout << lt2.empty() << endl;

对于剩下的接口函数大家可以参考文档自行解决

https://cplusplus.com/reference/list/list/?kw=list

5.list的迭代器失效

迭代器失效指的是迭代器指向的节点无效,即该节点被删除了,因为list的底层结构为带头循环双向链表,在进行插入操作时是不会导致list的迭代器失效的,只有在删除时才会失效,失效的是指向被删除节点的迭代器,其他迭代器不会受影响,所以在删除操作时要接收返回值

6.演示代码和测试用例连接

https://gitee.com/lin-ciyu/cplusplus/blob/master/STL_list/STL_list/Test.cpp

相关推荐
lqqjuly2 小时前
特殊的“Undefined Reference xxx“编译错误
c语言·c++
冰红茶兑滴水3 小时前
云备份项目--工具类编写
linux·c++
刘好念3 小时前
[OpenGL]使用 Compute Shader 实现矩阵点乘
c++·计算机图形学·opengl·glsl
酒鬼猿4 小时前
C++进阶(二)--面向对象--继承
java·开发语言·c++
姚先生974 小时前
LeetCode 209. 长度最小的子数组 (C++实现)
c++·算法·leetcode
小王爱吃月亮糖5 小时前
QT开发【常用控件1】-Layouts & Spacers
开发语言·前端·c++·qt·visual studio
aworkholic5 小时前
opencv sdk for java中提示无stiching模块接口的问题
java·c++·opencv·jni·opencv4android·stiching
程序员老冯头5 小时前
第十六章 C++ 字符串
开发语言·c++
Xenia2235 小时前
复习篇~第二章程序设计基础
c++·算法
想睡觉 . 我也想睡觉 .5 小时前
【C++算法】1.【模板】前缀和
开发语言·c++·算法