C++STL: list(双链表) 简单介绍,了解迭代器类型,list sort 的弊端

目录

1.list简单介绍

[1.0 assign 赋值](#1.0 assign 赋值)

[1.1 insert,erase的迭代器失效](#1.1 insert,erase的迭代器失效)

[1.2list不支持 operator ](#1.2list不支持 operator[ ])

[1.3 算法库sort不支持list使用,原因是迭代器类型](#1.3 算法库sort不支持list使用,原因是迭代器类型)

1.3.1迭代器类型

[1.4unique 除去相邻重复元素](#1.4unique 除去相邻重复元素)

[1.5 list 的 sort 函数 排序(不推荐,性能低)](#1.5 list 的 sort 函数 排序(不推荐,性能低))


C语言数据结构中我们就学习过链表, 链表又分为单链表和双链表。这里我们主要讲双链表

1.list简单介绍

list的基本接口和前面讲的vector的接口基本一致,重点讲不一样的:

1.0 assign 赋值

assign支持 一段迭代器区间,或者n个val赋值,迭代器可以不是同类型的,比如可以是vector的迭代器。

1.1 insert,erase的迭代器失效

list 是针对节点进行操作,insert不涉及扩容问题,所以insert不会迭代器失效

erase会迭代器失效,删除了节点就没了。

1.2list不支持 operator

list没有operator 重载。 是为vector 和 string等其他容器使用的,不支持全部容器,比如list

1.3 算法库sort不支持list使用,原因是迭代器类型

list 有 sort函数 ,是排序,算法库也有一个sort

用算法库的sort会发现,不能排序 list ,算法库的sort会报错

原因是 算法库 的 sort底层 是用 迭代器 相减 ,list的迭代器不支持相减

接下来从迭代器角度,深度理解这个原因:

1.3.1迭代器类型

查文档可发现,双链表是双向迭代器, 支持++,--但不支持加 + 减 -

单链表 是 单向迭代器 只支持++

vector 是 随机迭代器,++,--,+,- 全部支持

结合容器的底层空间特性,也大概能猜到它是什么迭代器。
双链表,底层空间不连续,是由节点链接,迭代器 it+或- n 的时间复杂度是O(n),性能很差(因为节点都是离散的,需要遍历多次++或--代替+,-的功能,才能找到节点) ,但是++,-- 是O(1),性能很好,所以双链表是双向迭代器
单链表,和双链表几乎一样,区别是只能往前,只能支持 ++ 所以是单向迭代器
vector,底层空间连续,可以完全由指针充当迭代器,指针本身支持+,-,++,--,效率都是O(1)直接通过地址计算,空间是连续的,不像双链表),所以是随机迭代器。

算法库的sort 的参数是 随机迭代器,因此list的不能使用

如果参数要求是双向迭代器 ,其实随机迭代器也能 ,因为是功能上包含关系

迭代器类型,其实是继承关系(继承和多态相关知识)。单向在双向内,单向,双向在随机内

再看一种特殊的迭代器类型:

IuputIterator ,这是什么鬼?
其实这是输入迭代器,C++高度抽象出来的一种特殊迭代器(后面的知识),还有只读迭代器。这里传单向,双向,随机都行

1.4unique 除去相邻重复元素

如标题,是除去 相邻 重复 元素 ,所以不相邻不行。那就需要和 sort 组合使用,把重复的挨在一起。

本质就是快慢双指针算法,判断元素是否相同,数据结构中讲过。了解这个函数

1.5 list 的 sort 函数 排序(不推荐,性能低)

单纯存储大量数据还是vector更好(不频繁插入,删除,挪动数据,且数据量巨大)。虽然他会扩容,但是扩容开销没想象那么大。扩容越扩容越慢

list 的 sort 是 底层是归并排序,它的时间复杂度是n*logn 库里的sort 快速排序也是n*logn ,看似一样,实际上性能相差了几倍。

时间复杂度只是告诉你他们在同一个量级,实际上还是有性能大小之分。

我们利用某种方法,测试list的 排序 和 库里的排序性能差异:

单位毫秒:

100万个数据:

这是debug版本下的测试 。不具参考性,因为debug会添加很多调试信息,我们再用release版本

如图,这说明list 的sort 效率比较低。 性能差异大,数据越大,性能差距越明显。

所以尽量不要用list sort

第二个测试:把 list 的值 通过迭代器区间构造 传给vector,然后再用std::sort 排序vector,最后把数据还给 list

对照组是,直接用 list sort 排序,我们对比一下他们的性能差异:

测试结果:

如图,即使涉及两步多余的赋值,构造操作,std::sort 仍比 list sort 快一倍。

这更说明了,vector更适合排序数据,存储数据。****(前提是没有大量的插入,删除,挪动数据,数据量巨大)

list sort 的弊端就是效率不高,请尽量小心使用

相关推荐
见过夏天5 小时前
C++ 基础入门完全指南
c++
用户805533698032 天前
不止三件套:QObject 属性系统全关键字与运行时反射!
c++·qt
BadBadBad__AK2 天前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境3 天前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境3 天前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
郝学胜_神的一滴4 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
卷无止境6 天前
C++ 的Eigen 库全解析
c++
卷无止境6 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴6 天前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
博客18007 天前
酷宝的使用方法,超好用的免费界面库,C++、MFC可用
c++·mfc·界面库·库来帮·酷宝