list的模拟实现

一、Node的封装

二、ListIterator的封装

三、list中基本功能的实现

一、Node的封装

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

二、ListIterator的封装

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

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

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

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

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

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

三、list中基本功能的实现

相关推荐
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠3 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾3 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres8213 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q3 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒3 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
世人万千丶3 天前
成语接龙小应用 - HarmonyOS ArkUI 开发实战-TextInput与List列表-PC版本
华为·list·harmonyos·鸿蒙·鸿蒙系统
WL学习笔记3 天前
单项不带头不循环链表
数据结构·链表
小糯米6013 天前
JS 数组
数据结构·算法·排序算法
未若君雅裁3 天前
Python 数据容器详解,list、tuple、str、set、dict 到底怎么选
windows·python·list