当前位置: 首页 > news >正文

烟台 网站建设互联网广告价格

烟台 网站建设,互联网广告价格,多语言网站 用什么cms,介绍政府网站的布局目录 一、反向迭代器 二、反向迭代器的实现 一、反向迭代器 之前的模拟实现vector、list 的时候,这些都是实现了正向迭代器,反向迭代器都没有实现,这里就要实现反向迭代器 反向迭代器也是适配器(配接器)的一种&#…

目录

一、反向迭代器

二、反向迭代器的实现


一、反向迭代器

        之前的模拟实现vector、list 的时候,这些都是实现了正向迭代器,反向迭代器都没有实现,这里就要实现反向迭代器

        反向迭代器也是适配器(配接器)的一种,反向迭代器的实现是对正向迭代器的封装,即实现的反向迭代器能支持多种容器,给出该容器的正向迭代器就能支持反向迭代器

        比如 vector 需要反向迭代器,那就把 vector 的正向迭代器传给 反向迭代器,它就可以通过正向迭代器转换出 vector 的反向迭代器。

        也就是说,实现的反向迭代器并包装的这个类,不是针对某个容器而是针对所有容器的,任何一个容器只要你实现了正向迭代器,就可以通过其适配出反向迭代器

要注意反向迭代器的错位访问

对于 list 而言,正向迭代器的 begin 和 end 位置如下

        begin 位于头结点的下一个节点,end 则位于尾结点的下一个节点,即头节点,正向迭代器 ++ 操作,迭代器是往后走的

反向迭代器 rbegin 和 rend 位置如下

        反向迭代器 rbegin() 位于正向迭代器 end() 的位置, 反向迭代器 rend() 位于正向迭代器 begin() 的位置,反向迭代器 ++操作迭代器是往前走的

vector 反向迭代器也是如此

对于 list 来说,反向迭代器解引用取数据,取的是头节点上一个节点位置的数据,vector 也是如此

二、反向迭代器的实现

Iterator.h

#pragma oncetemplate<class Iterator, class Ref, class Ptr>
class ReverseIterator
{typedef ReverseIterator<Iterator, Ref, Ptr> Self;
public:ReverseIterator(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;}private:Iterator _it;
};

下面套到 list 里面进行测试

//反向迭代器
typedef ReverseIterator<iterator, T&, T*> reverse_iterator;
typedef ReverseIterator<const_iterator, const T&, const T*> const_reverse_iterator;

在 list 里面添加反向迭代器代码

reverse_iterator rbegin()
{return reverse_iterator(end());
}reverse_iterator rend()
{return reverse_iterator(begin());
}

测试代码

void Test_ReverseIterator()
{fy::list<int> lt;lt.push_back(1);lt.push_back(2);lt.push_back(3);lt.push_back(4);lt.push_back(5);lt.push_back(6);fy::list<int>::iterator it = lt.begin();while (it != lt.end()){cout << *it << " ";++it;}cout << endl;fy::list<int>::reverse_iterator rit = lt.rbegin();while (rit != lt.rend()){cout << *rit << " ";++rit;}cout << endl;
}

 运行结果

list 的反向迭代器就完成了,下面测试 vector 的反向迭代器

把 Iterotor.h 拷贝一份到 vector 里面

//反向迭代器
typedef ReverseIterator<iterator, T&, T*> reverse_iterator;
typedef ReverseIterator<const_iterator, const T&, const T*> const_reverse_iterator;

在 vector 里面添加反向迭代器代码

reverse_iterator rbegin()
{return reverse_iterator(end());
}reverse_iterator rend()
{return reverse_iterator(begin());
}

测试代码

void Test_ReverseIterator()
{fy::vector<int> v;v.push_back(1);v.push_back(2);v.push_back(3);v.push_back(4);v.push_back(5);v.push_back(6);fy::vector<int>::iterator it = v.begin();while (it != v.end()){cout << *it << " ";++it;}cout << endl;//反向迭代器fy::vector<int>::reverse_iterator rit = v.rbegin();while (rit != v.rend()){cout << *rit << " ";++rit;}cout << endl;}

运行结果

----------------我是分割线---------------

文章到这里就结束了,下一篇即将更新

 

http://www.15wanjia.com/news/31572.html

相关文章:

  • 做网站原创要多少钱安卓优化大师下载安装到手机
  • html5网站首页代码做引流推广的平台600
  • 乐陵网站建设如何进行网络营销推广
  • 哈密网站建设今日新闻摘抄十条简短
  • 设计手机网站百度的推广广告
  • 移动网站适配南宁seo推广服务
  • 新闻网站开发模块网络销售平台有哪些软件
  • 企业服饰网站模板电商运营怎么自学
  • 建筑网站首页提交链接
  • 三层架构做网站还是系统在线种子资源库
  • 网站不需要什么备案搜狗推广登录平台官网
  • 网站顶部导航网站媒体推广
  • 成都网站制作创新互联软文范例大全800字
  • 用什么做网站方便如何做网络营销
  • 做网站guangxiyanda沈阳seo网站推广
  • vps可以做几个网站信息流投放平台
  • 网站建设综合实训日志策划推广方案
  • 台州电子商务网站建设seo标签优化方法
  • 沈阳网站建设公司哪家好网站的营销推广
  • 网站建设销售中遇到的问题教育培训网页设计
  • 网站建设企业类型是什么意思seo自动刷外链工具
  • 做网站日志步骤网站视频播放代码
  • 响应式网站设计规则网站外包
  • wordpress添加文章内容目录seoul是韩国哪个城市
  • 安徽省住房和城乡建设厅官网网站厦门人才网唯一官方网站登录入口
  • 现在最火的电商平台是什么广告网站建设网站排名优化
  • 网站设计ui百度如何优化排名靠前
  • 提供手机网站制作公司seo推广怎么做视频教程
  • 网站开发实训心得海南seo代理加盟供应商
  • 个人购物网站 怎么建长沙正规seo优化价格