【C++初阶】反向迭代器的实现

在这里插入图片描述

👦个人主页:@Weraphael
✍🏻作者简介:目前学习C++和算法
✈️专栏:C++航路
🐋 希望大家多多支持,咱一起进步!😁
如果文章对你有帮助的话
欢迎 评论💬 点赞👍🏻 收藏 📂 加关注✨


目录

  • 一、什么是迭代器
  • 二、如何模拟实现反向迭代器
  • 三、代码实现

一、什么是迭代器

若要访问容器里的元素,最常见的方式可以通过迭代器。迭代器是一个变量,相当于容器和算法之间的中介。迭代器可以指向容器中的某个元素,通过迭代器就可以读写它指向的元素。因此,迭代器可以认为是指针,但不一定就是指针。

特别注意:容器stackqueuepriority_queue是不支持迭代器的

常见的迭代器有正向迭代器和反向迭代器

【正向迭代器】
在这里插入图片描述

正向迭代器++是往后遍历,因此遍历的顺序为1 2 3 4

【代码实现】

#include <iostream>
#include <vector>
#include <list>
using namespace std;int main()
{vector<int> v{ 1, 2,3, 4 };vector<int>::iterator vit = v.begin();while (vit != v.end()){cout << *vit << ' ';vit++;}cout << endl;return 0;
}

【输出结果 】

在这里插入图片描述

【反向迭代器】

在这里插入图片描述

对比正向迭代器,反向迭代器++是往前遍历的,因此遍历的顺序为4 3 2 1

【代码实现】

#include <iostream>
#include <vector>
#include <list>
using namespace std;int main()
{vector<int> v{ 1, 2,3, 4 };vector<int>::reverse_iterator vrit = v.rbegin();while (vrit != v.rend()){cout << *vrit << ' ';vrit++;}cout << endl;return 0;
}

【输出结果】

在这里插入图片描述

二、如何模拟实现反向迭代器

我们发现,对比正向迭代器和反向迭代器,只有前后置++/--是有所差别的。因此,对于list可以将原来的正向迭代器给拷贝一份,然后将++运算符重载中修改为指向前一个结点,–-运算符重载修改为指向后一个结点。对于vector可以是类似于实现list正向迭代器一样,封装一个类,,然后运算符重载去处理。

可是以上这样实现就有点麻烦,我们可以看看库是如何实现的

在这里插入图片描述

从上我们可以发现,在库里面其实使用的是适配器来实现反向迭代器的,对正向迭代器进行了封装。用正向迭代器的++实现返向迭代器的++,用正向迭代器的--来实现反向迭代器的--

接下来再来看看库里是如何实现reverse_iterator

在这里插入图片描述

以上接口唯独最奇怪的是解引用,它解引用的结果是当前位置的前一个对象(*--tmp),但是再回过头重新看rbeginrend就会明白(上上图)

在这里插入图片描述

每次解引用都会先得到rbegin前一个位置的数据,直到rbegin == rend遍历结束,这里就体现了一个镜像对称特性,认为反向迭代器与正向迭代器是具有对称关系的

三、代码实现

#pragma once
namespace wj
{template<class Iterator, class Ref, class Ptr>struct ReverseIterator{Iterator _it;typedef ReverseIterator<Iterator, Ref, Ptr> Self;// 正向迭代器构造反向迭代器ReverseIterator(Iterator it):_it(it){}Ref operator*(){// --有副作用,可以拷贝一个副本tmp操作Iterator tmp = _it;return *--tmp;}Ptr operator->(){return &(operator*());}Self& operator++() // 前置{--_it;return *this;}Self operator++(int) // 后置{Iterator tmp(_it);_it--;return tmp;}Self& operator--(){++_it;return *this;}Self& operator--(int){Iterator tmp(_it);_it++;return tmp;;}bool operator!=(const Self& s) const{return _it != s._it;}bool operator==(const Self& s) const{return _it == s._it;}};
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/91717.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++】VS配置OpenCV/Libtorch环境

前言 本文是视频https://www.bilibili.com/video/BV1dp4y177L4的笔记。 OpenCV和Libtorch安装包&#xff1a;https://pan.baidu.com/s/1i3DqTcHFSC1rRDsIgYGCsQ?pwd8888 VS版本&#xff1a;2019 Opencv版本&#xff1a;3.4.1 Libtorch版本&#xff1a;2.0.1cu117 配置Open…

[论文笔记]DSSM

引言 这是DSSM论文的阅读笔记,后续会有一篇文章来复现它并在中文数据集上验证效果。 本文的标题翻译过来就是利用点击数据学习网页搜索中深层结构化语义模型,这篇论文被归类为信息检索,但也可以用来做文本匹配。 这是一篇经典的工作,在DSSM之前,通常使用传统机器学习的…

BMC相关知识

简介 BMC&#xff08;Baseboard Management Controller&#xff09;&#xff0c;基板管理控制器&#xff0c;普通PC没有&#xff0c;服务器产品必备。BMC是一个独立的系统&#xff0c;只要通电即可运行&#xff0c;服务器无需开机&#xff0c;不依赖其它软硬件&#xff0c;如O…

查漏补缺 - JS三 WebAPI

目录 BOMhistory DOM操作DOM1&#xff0c;dom.children 和 dom.childNodes 区别2&#xff0c;dom.remove()3&#xff0c;其他常用 API DOM 属性1&#xff0c;标准属性2&#xff0c;自定义属性 DOM 内容DOM样式DOM事件 JavaScript 包括 EcmaScript 和 WebAPI EcmaScript 包括 语…

OB Cloud上新,4.1版本现已全面开放

2022 年 8 月 10 日&#xff0c;OceanBase 宣布 OceanBase 公有云服务全球开服&#xff0c;帮助不同规模客户&#xff0c;在全球不同区域&#xff0c;享受同样优质的企业级数据库产品与服务。 经过近一年的发展&#xff0c;公有云业务取得了长足的发展&#xff0c;去年对客收入…

【基于空间纹理的残差网络无监督Pansharpening】

Unsupervised Pansharpening method Using Residual Network with Spatial Texture Attention &#xff08;基于空间纹理的残差网络无监督泛锐化方法&#xff09; 近年来&#xff0c;深度学习已经成为最受欢迎的泛锐化工具之一&#xff0c;许多相关方法已经被研究并反映出良好…

SpringBoot项目在启动后自动关闭

问题描述&#xff1a; 今天搭建了一个SpringBoot项目&#xff0c;但是在启动之后就自行关闭了&#xff0c;就像下面这样&#xff1a; 原因分析&#xff1a;在创建SpringBoot项目的时候&#xff0c;Web的依赖没有导入&#xff0c;默认以普通java项目运行导致的终止。 解决方案…

Java“牵手”1688商品详情数据,1688API接口申请指南

1688平台商品详情接口是开放平台提供的一种API接口&#xff0c;通过调用API接口&#xff0c;开发者可以获取1688商品的标题、价格、库存、月销量、总销量、库存、详情描述、图片等详细信息 。 获取商品详情接口API是一种用于获取电商平台上商品详情数据的接口&#xff0c;通过…

网络编程

1. 网络编程入门 1.1 网络编程概述 计算机网络 是指将地理位置不同的具有独立功能的多台计算机及其外部设备&#xff0c;通过通信线路连接起来&#xff0c;在网络操作系统&#xff0c;网络管理软件及网络通信协议的管理和协调下&#xff0c;实现资源共享和信息传递的计算机系统…

10个免费PPT下载资源网站分享

PPT超级市场https://pptsupermarket.com/ PPT超级市场是一个完全免费的PPT模板下载网站&#xff0c;不需要注册登录&#xff0c;点击下载就能直接使用。 叮当设计https://www.dingdangsheji.com/ 叮当设计是一个完全免费的PPT模板下载网站&#xff0c;每一套PPT的质量都很高。除…

说说我最近筛简历和面试的感受。。

大家好&#xff0c;我是鱼皮。 都说现在行情不好、找工作难&#xff0c;但招人又谈何容易&#xff1f;&#xff01; 最近我们公司在招开发&#xff0c;实习社招都有。我收到的简历很多&#xff0c;但认真投递的、符合要求的却寥寥无几&#xff0c;而且都是我自己看简历、选人…

域内密码喷洒

在Kerberos阶段认证的AS-REQ阶段&#xff0c;请求包cname对应的值是用户名&#xff0c;当用户名存在时候&#xff0c;密码正确和错误两种情况下&#xff0c;AS-REP返回包不一样&#xff0c;所以可以利用这一点对域用户名进行密码喷洒攻击 域内密码喷洒工具 Kerbrute kerbrut…