首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

反向迭代

在官方库中,反向迭代器是使用适配器封装的,即用普通的迭代器去作为适配器,然后封装出一个反向迭代器出来。  关于迭代器的解析,在介绍实习list以及迭代器这篇文章中有较详细讲解。...此处重点是反向迭代器的原理和实现。list---迭代器的原理和实现 开始实现反向迭代器 首先是类模板,Iterator代表的是适配器,Ref和Ptr代表的是引用和取地址。...{ ++it;//会调用正向迭代器的operator++(); return *this; }  反向迭代器的解引用 根据官方库中的源代码,我们可以分析得到,反向迭代器中的rbegin和rend...Ptr operator->() { return *(operator*()); } 反向迭代器的构造函数 只需在初始化列表上,将迭代器指向的节点或顺序表中的某个位置赋值给反向迭代器的对象即可...返回链表的尾节点,然后通过构造函数将反向迭代器的对象初始化,并且是浅拷贝,指向同一块空间 return reverse_iterator(begin()); } //const版本反向迭代器的

46920
您找到你想要的搜索结果了吗?
是的
没有找到

【C++】反向迭代

文章目录 一、什么是反向迭代器 二、STL 源码中反向迭代器的实现 三、reverse_iterator 的模拟实现 四、vector 和 list 反向迭代器的实现 一、什么是反向迭代器 C++ 中一共有四种迭代器...,反向迭代器的特点如下: rbegin() 相当于 end(); rend() 相当于 begin(); 反向迭代器++相当于正向迭代器–; 其他操作比如 * !...,而并没有去实现反向迭代器,今天我们就来探究如何实现反向迭代器。...---- 二、STL 源码中反向迭代器的实现 我们可以通过参考 STL 源码中反向迭代器的实现方式来学习如何实现反向迭代器,如下: //list.h部分源码 -- SGI版 template <class...reverse_iterator 的模板参数,而反向迭代器是 reverse_iterator 的对象,所以反向迭代器是一个容器适配器,它的适配容器就是对应的正向迭代器,这样它就能根据传递过来的正向迭代器的不同实例化出对应的反向迭代

85500

插入、流和反向迭代

(cout," ")); return 0; } 这样来循环都不用写了,用copy就能完成输出,上面的输出流也能重新绑定, 反向迭代器 类型和操作 反向迭代器是在容器中从尾部元素向首部元素反向移动的迭代器...除了forward_list之外其他容器都支持反向迭代器。 反向迭代器有rbegin,rend,crbegin和crend; 四种迭代器指向的容器位置如下所示: ?...string的字符,因为反向迭代器会反向操作容器中的元素。...string str = "apple,dinner"; cout << string(str.crbegin(), str.crend()) << endl; 输出为 rennid,elppa 反向迭代器的转换...反向迭代器可以用自带的base成员函数来转换为一个普通正向迭代器; string str = "apple,dinner"; cout << string(str.crend().base(),

48120

【C++】开始了解反向迭代

然而,当我们面临实现反向迭代器的需求时,是否需要重头开始,再次进行类的封装呢? 显然这种做法并非必要(不然就要手搓无数个反向迭代器了)。...因为反向迭代器与正向迭代器在功能上存在高度一致性,唯一的区别在于它们在容器中的移动方向相反。因此,我们可以采用适配器设计模式,对现有的正向迭代器进行二次封装,以此满足反向迭代器的需求。...,就给出链表的反向迭代器。...接下来我们也来实现一下自己的反向迭代器: 3 复刻反向迭代器 通过对反向迭代器的设计模式的了解,我们可以大致写一个框架: namespace bit { // 适配器 -- 复用 //给谁的正向迭代器就产生谁的正向迭代器...3.1 加减操作 根据反向迭代器的性质,我们可以借助正向迭代器的函数来实现反向迭代器的加减操作。

10010

【c++】反向迭代器的探究实现

,我们下面来实现另一种适配模式,我传入某一容器的正向迭代器来适配生成反向迭代器 比如传入List类的正向迭代器,适配出List的反向迭代器,传入vector正向迭代器,适配出vector的反向迭代器 template...= 总结编译器处理: 本来每个容器都要写一个反向迭代器的累,但是自己写,太费劲了 本质写一个反向迭代器的类模板,给编译器传不同的容器的正向迭代器实例化,编译器帮助我们实例化出各种容器的对应反向迭代器...编写一个通用的反向迭代器类模板可以省去为每个容器单独定义反向迭代器的麻烦。...它接收一个正向迭代器作为模板参数,反转了其遍历方向,使得利用正向迭代器的容器可以很容易地提供反向迭代能力 使用类模板可以使得编译器根据你向模板传递的不同正向迭代器类型,为每个具体的容器类型生成对应的反向迭代器实例...这个通用反向迭代器适配器遵循了一种 编写一次,处处使用的原则,极大地提高了代码的复用性 例如,在 ReverseIterator 模板中,只要定义一次,就可以用来产生各种支持正向迭代器的容器的反向迭代

8910

C++ STL学习之【反向迭代器】

,这正是适配器的核心思想 ---- ️正文 反向迭代器适用于所有的容器,因此它是作为一个单独的 .h 文件出现的,别的容器如果想使用,直接包含就行了 1、反向迭代器设计 反向迭代器 reverse_iterator...可以用来反向遍历容器,在某些场景下很实用 反向迭代器类中需要有:正向迭代器对象、构造函数 template struct __reverse_iterator {...注意:源码中的反向迭代器设计较为复杂,涉及 萃取 等操作,为了方便学习,这里实现的是简易版本 1.1、反向思想 何谓反向?...结果:1 2 3 4 5 反向迭代器:反向遍历 结果:5 4 3 2 1 注:库中的反向迭代器在设计时,为了最求极致的对称,rbegin() 指向最后一个有效元素的下一个位置,rend() 指向第一个有效元素...vector(反向迭代器版) list(反向迭代器版) ---- 总结 以上就是本篇关于 C++ STL 学习之【反向迭代器】的全部内容了,在本篇文章中,我们主要学习了反向迭代器类的思想及实现,最后分别用了

12720

【STL】reverse_iterator反向迭代器的实现

反向迭代器则与正向迭代器的遍历方向相反,从后往前反向遍历。...既然作为一种适配器模式,反向迭代器的实现肯定离不开正向迭代器,事实上也确实如此,反向迭代器的操作实际上底层都调用的是正向迭代器与之对应的接口。...2.1、反向迭代器的基本结构 既然作为一种适配器模式,反向迭代器的实现肯定离不开正向迭代器,所以该类的成员变量中需要存在一个正向迭代器,同时我们在实现时采用与正向迭代器相同的处理方式即:采用多参数模板完成...--操作(反向迭代器的方向是从后往前)。...而正向迭代器的--操作,是从后往前的,因此对于反向迭代器来说就相当于自己的++操作。

8610

【C++】STL——反向迭代器的模拟实现:迭代器适配器

前言 反向迭代器的使用相信大家都已经比较熟悉了,那我们这篇文章具体讲什么呢? ,这篇文章我们重点来讲一下反向迭代器的模拟实现。 那为什么我们之前不和正向迭代器放在一块讲呢?...那现在大家思考一个问题:单从使用的角度来看,反向迭代器和正向迭代器有什么区别?...所以,我们是不是就可以这样来实现反向迭代器: 直接把正向迭代器的代码拷贝一份,然后名字改一下,++和- -的操作改一下就行了。 然后list里面: 把反向迭代器的类型放进去。...哦豁,那我们的反向迭代器不就写好了嘛! 试一下: 哎呀,是不是没问题啊。 那这样看来,要实现一个反向迭代器好像也不难啊。 2....但是对于适配器的实现方式: 你给我一个list的正向迭代器,我可以给你适配出list的反向迭代器,那如果给一个vector的正向迭代器,能否适配出vector的反向迭代器呢?

11910

【STL】iterator adapters_反向迭代器的实现

反向迭代器则与正向迭代器的遍历方向相反,从后往前反向遍历。...既然作为一种适配器模式,反向迭代器的实现肯定离不开正向迭代器,事实上也确实如此,反向迭代器的操作实际上底层都调用的是正向迭代器与之对应的接口。...2.1、反向迭代器的基本结构 既然作为一种适配器模式,反向迭代器的实现肯定离不开正向迭代器,所以该类的成员变量中需要存在一个正向迭代器,同时我们在实现时采用与正向迭代器相同的处理方式即:采用多参数模板完成...因此对于反向迭代器来说就相当于自己的--操作(反向迭代器的方向是从后往前)。...而正向迭代器的--操作,是从后往前的,因此对于反向迭代器来说就相当于自己的++操作。

17420

【C++STL】list(常见接口、模拟实现、反向迭代器)

const迭代器 用const迭代器,需要重新弄一个类,而const迭代器跟普通迭代器基本一样,只修改了部分,如果为此就重新弄一个类,代码就太冗余了。...list与vector的对比 反向迭代反向迭代器的++就是正向迭代器的--,反向迭代器的--就是正向迭代器的++,因此反向迭代器的实现可以借助正向迭代器,即:反向迭代器内部可以包含一个正向迭代器,对正向迭代器的接口进行...反向迭代器完整代码 #pragma once //所以容器的反向迭代器 //迭代器适配器 namespace qjh { //vector::iterator template //给谁的正向迭代器,就适配出对应的反向迭代器 struct ReverseIterator { typedef ReverseIterator...const iterator不是我们需要的const迭代器 //const 迭代器本身可以++等操作 const_iterator begin() const { return const_iterator

7110

c++stl之反向迭代器用法及注意事项!!!

反向迭代器 1.定义: 在容器中从尾元素向首元素反向移动的迭代器 对于反向迭代器,递增和递减的含义会颠倒过来 递增一个反向迭代器会移动到前一个元素 递减一个迭代器会移动到下一个元素...crend() 下面两个c开头的是反向迭代器的const版本,即不能修改迭代器指向位置的值 3.反向迭代器与正向迭代器的比较 4.反向迭代器应用之逆序打印数组元素 vector vec...我们只能从既支持++也支持–的迭代器来定义反向迭代器....毕竟反向迭代器的目的是在序列中反向移动。...反向迭代器的目的是表示元素范围,而这些范围是不对称的,这导致一个重要的结果: 当我们从一个普通迭代器初始化一个反向迭代器,或是给一个反向迭代器赋值时,结果迭代器与原迭代器指向的并不是相同的元素。

86430

【C++】STL 容器 - list 双向链表容器 ② ( list 常用 api 简介 | 首尾 添加 删除 元素 | 获取首尾元素 | 正向迭代反向迭代 )

文章目录 一、元素操作 1、首尾 添加 / 删除 元素 2、获取 首尾 元素 二、迭代器遍历容器 1、正向迭代反向迭代 2、代码示例 一、元素操作 1、首尾 添加 / 删除 元素 list 双向链表容器...二、迭代器遍历容器 1、正向迭代反向迭代 std::list 双向链表容器 提供了 begin、end、rbegin 和 rend 这几个成员函数,用于 获取 迭代访问链表中的元素 的 迭代器 , 函数原型如下...end() const; 获取指向尾元素的反向迭代器 : 该函数返回一个反向迭代器 , 指向链表的最后一个元素 ; 如果链表为空 , 则此操作未定义 ; 反向迭代器从链表的尾部向头部移动 ; 获取指向首元素之前的反向迭代器...: 返回一个反向迭代器 , 指向链表的 超出头部 ”的位置 , 即第一个元素的前一个位置 ; 该迭代器 它用于与 rbegin 一起实现完整的逆向迭代 ; reverse_iterator rend(...= lstInt.end(); it++) { cout << *it << " "; } cout << endl; 反向迭代示例 : // 反向迭代 for (list::reverse_iterator

23810

【C++】STL 容器 - set 集合容器 ② ( set 集合容器常用 api 简介 | 使用迭代器进行正向迭代反向迭代 | 集合容器插入元素 | 插入单个元素 | 插入多个元素 )

一、set 集合容器遍历 1、使用迭代器进行正向迭代反向迭代 std::set 集合容器 提供了 begin、end、rbegin 和 rend 这几个成员函数,用于 获取 迭代访问链表中的元素 的...end() const; 获取指向尾元素的反向迭代器 : 该函数返回一个反向迭代器 , 指向集合容器的最后一个元素 ; 如果集合容器为空 , 则此操作未定义 ; 反向迭代器从集合的尾部向头部移动 ;...获取指向首元素之前的反向迭代器 : 返回一个反向迭代器 , 指向集合的 超出头部 ”的位置 , 即第一个元素的前一个位置 ; 该迭代器 它用于与 rbegin 一起实现完整的逆向迭代 ; reverse_iterator...= se.end(); it++) { cout << *it << " "; } // 回车换行 cout << endl; 反向迭代示例 : // 遍历 set 集合容器 , 反向迭代...= se.end(); it++) { cout << *it << " "; } // 回车换行 cout << endl; // 遍历 set 集合容器 , 反向迭代 for (set

50710

迭代

如果给定一个list或tuple,可以通过for循环来遍历这个list或tuple,这种遍历我们称为迭代(Iteration) 在Python中,迭代是通过for ... in来完成的 Python...的for循环抽象程度要高于C的for循环,因为Python的for循环不仅可以用在list或tuple上,还可以作用在其他可迭代对象上 当使用for循环时,只要作用于一个可迭代对象,for循环就可以正常运行...,而无需太关心该对象究竟是list还是其他数据类型 任何可迭代对象都可以作用于for循环,包括自定义的数据类型,只要符合迭代条件,就可以使用for循环 迭代list   迭代list是通过下标完成的...  for x in range(5):     print(x) 迭代dict   list这种数据类型虽然有下标,但很多其他数据类型是没有下标的,但只要是可迭代对象,无论有无下标,都可以迭代,比如...,整数是否可迭代 输出下标并迭代   Python内置的enumerate函数可把list变成索引-元素对,这样就可以在for循环中同时迭代索引和元素本身 for i, value in enumerate

59910

python迭代、可迭代对象、迭代器及生

迭代 通常意义上的迭代是指:重复执行一系列运算,从前面的量依次推出后面的量的过程,每一次迭代的结果,会作为下一次迭代的初始值。...可迭代对象与迭代器 可迭代对象:使用内置iter函数可以获取迭代器的对象,称为可迭代对象。通常指实现了能返回迭代器的__iter__方法或实现了__getitem__方法且其参数从0开始索引的对象。...通常情况下,迭代器也应该实现__iter__方法,迭代器的__iter__方法应该返回其自身(self),因为实现了__iter__方法,所以迭代器可迭代。...区别与联系:迭代器可以迭代,但可迭代对象不是迭代器。...可迭代对象一定不能是自身的迭代器,即可迭代对象一定不能实现__next__方法;迭代器应该一直可以迭代,其__iter__方法应该返回自身;可迭代对象可以重复使用(可以不断生成新的迭代器),但迭代器只能用一次

1.3K20

迭代(iterable)和迭代

简介: 迭代(iterable) #任何可迭代对象都可以作用于for循环,包括我们自定义的数据类型,只要符合迭代条件,就可以使用for循环 d = {'a': 1, 'b': 2, 'c': 3} #对...dict迭代 for k,v in d.迭代(iterable)#任何可迭代对象都可以作用于for循环,包括我们自定义的数据类型,只要符合迭代条件,就可以使用for循环d = {'a': 1, 'b':...2, 'c': 3} #对dict迭代for k,v in d.items(): # 如果要同时迭代key和value,可以用for k, v in d.items()print(k,v)#默认情况下...,dict迭代的是key # 如果要迭代value,可以用for value in d.values()#字符串也是可迭代对象,因此,也可以作用于for循环#如何判断一个对象是可迭代对象呢?...#可以被next()函数调用并不断返回下一个值的对象称为迭代器:Iterator#生成器都是Iterator对象,但list、dict、str虽然是Iterable,却不是Iterator。

81420

策略迭代和值迭代

我们可以把策略迭代和值迭代看成是一种表格型的方法, Q \in \mathbb{R}^{status\_num \times action\_num} ,即设置一个状态数和动作数构成的矩阵, Q[i,j...策略迭代 策略迭代的想法是分两步: 第一步:策略评估遍历每一个状态,计算该状态下根据现有策略执行不同动作的累积回报的期望,重复上述计算直到收敛,即在第t次遍历完所有状态后的值函数和第t-1次的遍历完所有的状态后的值函数没有变化或者变化小于阈值...以下为策略迭代的伪代码,可以参考上述的文字描述进行理解 值迭代 因为策略迭代每次都需要等到每个状态对应的值函数收敛后,再进行策略的更新与提升,但有时候即使状态对应的值函数没有收敛,也可以进行策略的改善...值迭代就是从这个想法出发提出的方法,他与策略迭代不同的是策略迭代每次都需要等到值函数收敛后在进行策略提升,值迭代是在计算该状态下不同动作的值函数后,寻找最大的值函数对应的动作,进行保留,当不同状态的值函数收敛后...代码 本文对应的方法已经上传到了github上面,并对代码进行了注释,希望对大家理解策略迭代和值迭代有帮助。

1.4K30

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券