博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(原創) 如何使用reverse_iterator? (C/C++) (STL)
阅读量:7056 次
发布时间:2019-06-28

本文共 1232 字,大约阅读时间需要 4 分钟。

若要將vector中反過來列印,該怎麼做呢?STL提供了reverse_iterator。

 1
ExpandedBlockStart.gif
ContractedBlock.gif
/**/
/* 
 2InBlock.gif(C) OOMusou 2006 http://oomusou.cnblogs.com
 3InBlock.gif
 4InBlock.gifFilename    : ReverseIterator.cpp
 5InBlock.gifCompiler    : Visual C++ 8.0 / ISO C++
 6InBlock.gifDescription : Demo how to use reverse_iterator
 7InBlock.gifRelease     : 12/17/2006 1.0
 8ExpandedBlockEnd.gif*/
 9
None.gif#include 
<
iostream
>
10
None.gif#include 
<
vector
>
11
None.gif#include 
<
algorithm
>
12
None.gif
13
None.gif
using
 
namespace
 std;
14
ExpandedBlockStart.gifContractedBlock.gif
int
 main() 
dot.gif
{
15ExpandedSubBlockStart.gifContractedSubBlock.gif  int ia[] = dot.gif{
123}
;
16InBlock.gif  vector<int> ivec(ia, ia + sizeof(ia) / sizeof(int));
17InBlock.gif
18InBlock.gif  // use reverse_iterator by for loop
19InBlock.gif  for(vector<int>::reverse_iterator r_iter = ivec.rbegin(); r_iter != ivec.rend(); ++r_iter) 
20InBlock.gif    cout << *r_iter << " ";
21InBlock.gif
22InBlock.gif  cout << endl;
23InBlock.gif
24InBlock.gif  // use ordinary iterator to print reversely
25ExpandedSubBlockStart.gifContractedSubBlock.gif  for(vector<int>::const_iterator iter = (--ivec.end()); iter >= ivec.begin();iter--dot.gif{
26InBlock.gif    cout << *iter << " ";
27InBlock.gif    if (iter == ivec.begin()) 
28InBlock.gif      break;
29ExpandedSubBlockEnd.gif  }
30InBlock.gif
31InBlock.gif  cout << endl;
32InBlock.gif
33InBlock.gif  // use reverse_iterator with copy() algorithm
34InBlock.gif  copy(ivec.rbegin(), ivec.rend(), ostream_iterator<int>(cout, " "));
35InBlock.gif  cout << endl;
36ExpandedBlockEnd.gif}

執行結果

None.gif
3
 
2
 
1
None.gif
3
 
2
 
1
None.gif
3
 
2
 
1
None.gif請按任意鍵繼續 . . .

19行的for loop,使用了reverse_iterator,讓我們很簡單的如操作一般的iterator般去處理reverse_iterator。

25行到29行,使用了一般的iterator去處理,程式有點詭異,主要是讓我們看出,若沒有reverse_iterator,程式有多難寫。

copy() algorithm也可搭配reverse_iterator,只需一行就可以了。

转载地址:http://tjgol.baihongyu.com/

你可能感兴趣的文章
[root@AY140716161543837722Z ~]# man top
查看>>
C语言基础及指针⑩预编译及jni.h分析
查看>>
java打开IE浏览器
查看>>
PHP中$this的使用情况
查看>>
webview页面随设备分辨率缩放
查看>>
调侃面向对象编程的23种设计模式
查看>>
8-pandas聚合运算
查看>>
【绿色系统】如何恢复XP“显示桌面”按钮
查看>>
在ubuntu 11.10 下安装谷歌输入法
查看>>
Apache Hive2.1.0安装笔记
查看>>
django中翻译处理国际化方法
查看>>
三:JVM学习-内存分配以及回收策略
查看>>
spring redis 配置子域名共享session (有点坑)
查看>>
Linux 条件变量 pthread_cond_signal及pthread_cond_wait
查看>>
比AtomicInteger更高效的并发计数器LongAdder
查看>>
Forms开发中触发器的执行顺序
查看>>
SEO博客三个月没更新排行骤步康复
查看>>
JQuery 插件开发的入门介绍
查看>>
马哥2016全新Linux+Python高端运维班第五周作业
查看>>
联想扬天A4680R台式电脑增加内存不识别的解决方案
查看>>