list的迭代器详讲

1.list的迭代器就是封装了节点指针的类

2.迭代器失效

迭代器失效即迭代器封装的节点指针无效 。因为 list 的底层结构为带头结点的双向循环链表 ,因此 list 中进行插入时是不会导致 list 的迭代 器失效的,只有在删除时才会失效,并且失效的只是指向被删除节点的迭代器,其他迭代器不会受到影响

3.list的反向迭代器实现

cpp 复制代码
template<class Iterator>
class ReverseListIterator
{
 // 注意:此处typename的作用是明确告诉编译器,Ref是Iterator类中的类型,而不是静态成员变量
 // 否则编译器编译时就不知道Ref是Iterator中的类型还是静态成员变量
 // 因为静态成员变量也是按照 类名::静态成员变量名 的方式访问的
public:
 typedef typename Iterator::Ref Ref;
 typedef typename Iterator::Ptr Ptr;
 typedef ReverseListIterator<Iterator> Self;
public:
 //
 // 构造
 ReverseListIterator(Iterator it): _it(it){}
 //
 // 具有指针类似行为
 Ref operator*(){
     Iterator temp(_it);
     --temp;
     return *temp;
 }
 Ptr operator->(){ return &(operator*());}
 //
 // 迭代器支持移动
 Self& operator++(){

     --_it;
     return *this;
 }

Self operator++(int){
     Self temp(*this);
     --_it;
     return temp;
 }


Self& operator--(){
     ++_it;
     return *this;
 }

Self operator--(int)
 {
     Self temp(*this);
     ++_it;
     return temp;
 }
 //
 // 迭代器支持比较
 bool operator!=(const Self& l)const{ return _it != l._it;}
 bool operator==(const Self& l)const{ return _it != l._it;}
 Iterator _it;
};

反向迭代器和正向迭代器相比,只是++和--的方向变了,因此反向迭代器的实现思路是适配器,即:反向迭代器内部可以包含一个正向迭代器,对正向迭代器的接口进行包装即可。

相关推荐
君鼎37 分钟前
排序算法——详解
数据结构·算法·排序算法
卫青~护驾!1 小时前
c++数据结构8——二叉树的性质
数据结构·算法
怀旧,1 小时前
【C语言】C语言经典小游戏:贪吃蛇(上)
c语言·数据结构
. . . . .1 小时前
文件索引:数组、二叉树、二叉排序树、平衡树、红黑树、B树、B+树
数据结构·b树
半桔2 小时前
【烧脑算法】不定长滑动窗口:从动态调整到精准匹配以灵活特性实现高效破题
数据结构·c++·算法·leetcode·面试·职场和发展·排序算法
cy晔2 小时前
B树和B+树
数据结构·b树
南玖yy2 小时前
C++ 类模板三参数深度解析:从链表迭代器看类型推导与实例化(为什么迭代器类模版使用三参数?实例化又会是怎样?)
开发语言·数据结构·c++·人工智能·windows·科技·链表
二猛子3 小时前
排序算法-归并排序与快速排序
数据结构·c++·算法·排序算法
L_1421906875 小时前
数据结构之排序
数据结构·算法·排序算法
小纭在努力8 小时前
【算法设计与分析】实验——改写二分搜索算法,众数问题(算法分析:主要算法思路),有重复元素的排列问题,整数因子分解问题(算法实现:过程,分析,小结)
数据结构·python·学习·算法·算法设计与分析·实验报告·实验