额外的迭代器

除了为每个容器定义的迭代器外,标准库在头文件iterator中还定义了额外几种迭代器:

插入迭代器:

插入器是一种迭代器适配器,它接受一个容器,生成一个迭代器,能实现向给定容器添加元素。

插入器有三种类型,差异在于元素插入的位置:

* back_inserter创建一个使用push_back的迭代器。

* front_inserter创建一个使用push_front的迭代器。

* inserter创建一个使用insert的迭代器。此函数接受第二个参数,这个参数必须是一个指向给定容器的迭代器。元素将被插入到给定迭代器所表示的元素之前。

iostream 迭代器:

虽然iostream类型不是容器,但标准库定义了可以用于这些IO类型对象的迭代器。istream_iterator读取输入流,ostream_iterator向一个输出流写数据。这些迭代器将它们对应的流当作一个特定类型的元素序列来处理。通过使用流迭代器,可以使用泛型算法从流对象读取数据以及向其写入数据。

cpp 复制代码
istream_iterator<int> in_iter(cin), eof;  //从cin读取int
//eof被定义为空的istream_iterator,因此可以当作尾后迭代器来使用。对于一个绑定到流的迭代器,一旦其
//关联的流遇到文件尾或遇到IO错误,迭代器的值就与尾后迭代器相等。
vector<int> vec(in_iter,eof);  //从迭代器范围构造vec
cpp 复制代码
ostream_iterator<int> out_iter(cout," ");
for(auto e:vec)
    *out_iter++ = e;  //赋值语句实际上将元素写到cout
cout<<endl;
//  此程序将vec中的每个元素写到cout,每个元素后加一个空格

反向迭代器:

反向迭代器就是在容器中从尾元素向首元素反向移动的迭代器。

相关推荐
xiaoye-duck3 小时前
《算法题讲解指南:递归,搜索与回溯算法--递归》--3.反转链表,4.两两交换链表中的节点,5.快速幂
数据结构·c++·算法·递归
山栀shanzhi4 小时前
归并排序(Merge Sort)原理与实现
数据结构·c++·算法·排序算法
Trouvaille ~4 小时前
【递归、搜索与回溯】专题(七):FloodFill 算法——勇往直前的洪水灌溉
c++·算法·leetcode·青少年编程·面试·蓝桥杯·递归搜索回溯
zhooyu5 小时前
二维坐标转三维坐标的实现原理
c++·3d·opengl
10Eugene5 小时前
C++/Qt自制八股文
java·开发语言·c++
「QT(C++)开发工程师」5 小时前
C++11 新特性 正则表达式、随机数库、元组
c++·正则表达式
free-elcmacom6 小时前
C++ 默认参数详解:用法、规则与避坑指南
开发语言·c++
Albert Edison7 小时前
【ProtoBuf 语法详解】Any 类型
服务器·开发语言·c++·protobuf
无忧.芙桃7 小时前
C++11的部分内容(上)
c++
小璐资源网7 小时前
C++中如何正确区分`=`和`==`的使用场景?
java·c++·算法