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

青岛高品质网站制作广州seo好找工作吗

青岛高品质网站制作,广州seo好找工作吗,2018年做网站,专业设计素材网站目录 二,全部代码 三,设计思路 1. 讨论 2. 关于迭代器文档一个小细节 结语 一,前言 如果有小伙伴还未学习普通迭代器,请参考这篇文章中的普通迭代器实现。 【STL】list用法&试做_底层实现_花果山~~程序猿的博客-CSDN…

目录

二,全部代码

三,设计思路 

1. 讨论

2. 关于迭代器文档一个小细节 

结语


 

一,前言

如果有小伙伴还未学习普通迭代器,请参考这篇文章中的普通迭代器实现。

【STL】list用法&试做_底层实现_花果山~~程序猿的博客-CSDN博客

 参考list源码,这里直接说结果,发现源码通过借用普通迭代器来构造反向迭代器。

二,全部代码

namespace my_list
{template <class T>struct list_node{list_node(const T& data = T()): _data(data), _next(nullptr), _prv(nullptr){}T _data;list_node* _next;list_node* _prv;};template <class T, class Ref, class Ptr>struct list_iterator{typedef list_node<T> Node;typedef list_iterator< T, Ref, Ptr> iterator;Node* _node;list_iterator(Node* node): _node(node){}bool operator!= (const iterator& it){return _node != it._node;}bool operator==(const iterator& it){return _node == it._node;}iterator& operator++(){_node = _node->_next;return *this;}iterator& operator--(){_node = _node->_prv;return *this;}iterator operator++(int){iterator tmp(*this);_node = _node->_next;return *tmp;}Ptr operator*(){return _node->_data;}Ref operator->(){return &(operator*());}};template <class Iterator, class Ref, class Ptr>struct _reverse_iterator{typedef _reverse_iterator<Iterator, Ref, Ptr>  reverse_iterator;Iterator _cur;_reverse_iterator(const Iterator& cur): _cur(cur){}reverse_iterator& operator++(){--_cur;return *this;}reverse_iterator operator++(int){reverse_iterator temp(*this);--_cur;return temp;}reverse_iterator& operator--(){++_cur;return _cur;}reverse_iterator operator--(int){reverse_iterator temp(*this);++_cur;return temp;}// != bool operator!=(const reverse_iterator& end){return _cur != end._cur;}bool operator==(const reverse_iterator&  end){return _cur == end._cur;}// *     Ptr operator*() {auto tmp = _cur;--tmp;return *tmp;}// ->Ref operator->(){return &(operator*());}};template <class T>class list{typedef list_node<T> Node;public:typedef list_iterator<T, T*, T&>  iterator;typedef list_iterator<T, const T*, const T&> const_iterator;typedef _reverse_iterator<iterator, T*, T&> reverse_iterator;typedef _reverse_iterator<const_iterator, const T*, const T&> const_reverse_iterator;reverse_iterator rbegin(){return reverse_iterator(end());}const_reverse_iterator rbegin() const{return const_reverse_iterator(end());}reverse_iterator rend(){return reverse_iterator(begin());}const_reverse_iterator rend() const{return const_reverse_iterator(begin());}iterator begin(){return iterator(_head->_next);}iterator end(){return iterator(_head);}const_iterator begin() const{return const_iterator(_head->_next);}const_iterator end() const{return const_iterator(_head);}
..... //list其他成员函数这里就不再赘述了

三,设计思路 

设计思路比较简单,本质上是复用普通迭代器的函数,其他重载函数思想跟普通函数差不多。

但这里也有一个比较艺术性的设计:

1. 讨论

那这里我们来讨论一下,这个反向迭代器是否能给vector使用??  答案是肯定的

看图:

结论:反向迭代器:迭代器的适配器。

2. 关于迭代器文档一个小细节 

那是不是所有的容器都合适呢? 

不一定,因为容器的普通迭代器最起码要支持++,--接口(比如:foward_list就不支持--,所以其没有反向迭代器)

这里补充一些关于[STL]文档的使用,从迭代器功能角度分为三类:

1. forward_iterator  (单向迭代器)      支持——>  ++                比如: foward_list等等

2. bidirectional_iterator(双向迭代器)   ——>  ++  --            比如: list等

3. radom_access_iterator  (随机迭起器) ——>  ++ --  + -   比如:vector, deque等, 第三中迭代器继承1,2种

那意义又是什么??

意义:就是提示在使用迭代器时,接口会提示你合适的的迭代器类型。

 

结语

   本小节就到这里了,感谢小伙伴的浏览,如果有什么建议,欢迎在评论区评论,如果给小伙伴带来一些收获请留下你的小赞,你的点赞和关注将会成为博主创作的动力

http://www.jinmujx.cn/news/117375.html

相关文章:

  • 百度做网站投广告地推接单网
  • 烟台市科技局网站如何进行搜索引擎优化?
  • 做企业网站 空间怎么买新手怎么推广自己的店铺
  • 什么网站教你做美食制作网页多少钱
  • 怎样给网站找空间做备案论坛外链代发
  • 动态网站开发pdfseo关键词推广渠道
  • 网页设计基础考试题目长沙关键词优化服务
  • 深圳市九号公告最新消息seo关键词外包公司
  • 法律网站开发网络销售工作靠谱吗
  • 益阳做网站的公司什么平台可以发广告引流
  • robots.txt 禁止爬行整个网站网站策划书的撰写流程
  • 济南网站建设公司哪个好点呢seo优化工具软件
  • 上海网站建设300上海专业seo排名优化
  • 网站地图页面设计海外推广渠道
  • 汽车网站建设需要多少钱国外seo大神
  • 一个网站页面设计多少钱东莞网站seo公司
  • 零基础搭建网站免费推广的网站平台
  • 网站建设市场行情报价网络seo优化推广
  • 网站后台动态播放怎么做的147seo工具
  • b2b 网站制作白酒最有效的推广方式
  • 莆田网站建设开发网站seo报价
  • 玩具网站建设策划书网络营销的基本内容有哪些
  • 免费手机网站制作app软文推广产品
  • 衡水做外贸网站建设百度新闻发布
  • 湖南做网站 多少钱磐石网络seo网站排名全选
  • 营销型网站建设与推广贵阳百度快照优化排名
  • 网站做盗版视频赚钱吗百度收录查询api
  • 济南网站建设排名2021年近期舆情热点话题
  • 黑龙江省和城乡建设厅网站网站排名优化多少钱
  • 首页>新闻>正文 网站怎么做友情链接你会回来感谢我