list的模拟实现

一、Node的封装

二、ListIterator的封装

三、list中基本功能的实现

一、Node的封装

此中有一点会总是引起大家的疑惑,就是为什么这里使用的为struct而不是class,因为在下面封装的ListIterator和list中会经常用到Node,而如果不弄成公有的话,就需要在class中弄成友元,比较麻烦,所以一般程序员都喜欢直接使用struct

二、ListIterator的封装

2-1 首先是一个简单的迭代器封装,想一下这几个问题:

迭代器,此处为什么要进行封装呢?

因为链表的结构是不同于vector的,vector的物理结构是连接在一起的,每次指针++,就是跨过一个指针的大小,来到另一个地址上,拿到下一个值,但是对于链表,由于其节点是随机放置的,无法使用传统的++来进行遍历等,因此就需要利用到封装,来重新加载运算符++,--,!=等。

但是,如果是具有常性的链表,要怎么访问?也就是需要再弄一个迭代器是可以实现常量遍历的,所以还要构造一个具有常性的迭代器,也就是迭代器所指向的内容是不可以更改的,但是迭代器本身是可以更改的。

由于为了减少代码的数量,就思考能不能使用一个类似模板的东西,来把参数带入到里面,其类型就转化为对应的参数。

把对应更改的代码放置到下面(大体是不变的):

三、list中基本功能的实现

相关推荐
yuannl103 小时前
数据结构----队列的实现
数据结构
Mr_Xuhhh3 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
Ricardo-Yang5 小时前
SCNP语义分割边缘logits策略
数据结构·人工智能·python·深度学习·算法
soragui5 小时前
【Python】第 4 章:Python 数据结构实现
数据结构·windows·python
samroom6 小时前
【鸿蒙应用开发 Dev ECO Studio 5.0版本】从0到1!从无到有!最全!计算器------按钮动画、滑动退格、中缀表达式转后缀表达式、UI设计
数据结构·ui·华为·typescript·harmonyos·鸿蒙
算法鑫探6 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
王老师青少年编程6 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举
Mr_Xuhhh7 小时前
深入理解二叉树:从数据结构到算法实战
数据结构·算法
ysa0510308 小时前
斐波那契上斐波那契【矩阵快速幂】
数据结构·c++·笔记·算法
早睡的叶子8 小时前
onnx模型数据结构分析,用于解析onnx模型
数据结构