C++反向迭代器的实现

一、反向迭代器的定义

  • 在容器中从尾元素向首元素反向移动的迭代器

  • 对于反向迭代器,递增和递减的含义会颠倒过来

  • 递增一个反向迭代器会移动到前一个元素

  • 递减一个迭代器会移动到下一个元素

二、反向迭代器的实现

cpp 复制代码
// 适配器 -- 复用
template<class Iterator, class Ref, class Ptr>
struct Reverse_iterator
{
	typedef Reverse_iterator<Iterator, Ref, Ptr> Self;
	Iterator _it;
	Reverse_iterator(Iterator it)
		:_it(it)
	{}
	Ref operator*()
	{
		Iterator tmp = _it;
		return *(--tmp);
	}
	Ptr operator->()
	{
		return &(operator*());
	}
	Self& operator++()
	{
		--_it;
		return *this;
	}
	Self& operator--()
	{
		++_it;
		return *this;
	}
	bool operator==(const Self& s)
	{
		return _it == s._it;
	}
	bool operator!=(const Self& s)
	{
		return _it != s._it;
	}
};

在实现时。我们实际是复用iterator,来实现Reverse_iterator。

所以在构造函数中,我们直接使用iterator对反向迭代器进行初始化。

在解引用操作时,因为从end()位置开始,所以要先--,获得新的位置,但不改变原来的_it ,所以建立一个临时对象对其进行--操作。

三、rbegin以及rend

为了实现rbegin或者rend,我们首先要在list或者vector中定义:

cpp 复制代码
typedef Reverse_iterator<iterator, T&, T*> reverse_iterator;
typedef Reverse_iterator<const_iterator, const T&, const T*> const_reverse_iterator;

rbegin:

cpp 复制代码
reverse_iterator rbegin()
{
	return reverse_iterator(end());
}

const_reverse_iterator rbegin() const
{
	return const_reverse_iterator(end());
}

rend:

cpp 复制代码
reverse_iterator rend()
{
	return reverse_iterator(begin());
}

const_reverse_iterator rend() const
{
	return const_reverse_iterator(begin());
}
相关推荐
是店小二呀2 分钟前
【优选算法 | 字符串】字符串模拟题精选:思维+实现解析
android·c++·算法
摆烂且佛系6 分钟前
FastByteArrayOutputStream和ByteArrayInputStream有什么区别
java·开发语言
不爱学英文的码字机器12 分钟前
[操作系统] 策略模式进行日志模块设计
c++·策略模式
Chandler2414 分钟前
Go语言:json 作用和语法
开发语言·golang·json
凤年徐16 分钟前
【C/C++】自定义类型:结构体
c语言·开发语言·c++·经验分享·笔记·算法
能来帮帮蒟蒻吗34 分钟前
Python -将MP4文件转为GIF图片
开发语言·python·学习·视频
忆源38 分钟前
【Qt】之音视频编程2:QtAV的使用篇
开发语言·qt·音视频
DARLING Zero two♡43 分钟前
C++效率掌握之STL库:map && set底层剖析及迭代器万字详解
c++·stl·set·map
绯樱殇雪1 小时前
编程题 02-线性结构3 Reversing Linked List【PAT】
c++·pat考试
程序员阿鹏1 小时前
Git的安装和配置(idea中配置Git)
java·开发语言·ide·git·intellij-idea·idea