C++学习笔记13

迭代器

概述

C++中的迭代器类似于指针,用于指示容器中的某个元素,一般用来遍历容器中的元素。比较迭代器是否相等用==,!=,有很多朋友会对迭代器进行<或>等操作,但最好别这么做,因为这种行为就如同比较指针存储的地址大小,这是没有意义的

分类

C++中的迭代器可分为5类,分别是:①随机访问迭代器 ②双向迭代器 ③前向迭代器 ④输出迭代器 ⑤输入迭代器。这5中迭代器的功能按前述顺序依次减弱。
  为什么要分为这么多种类型的迭代器?
为了使用最合适的工具,编写算法时在满足要求的基础上要尽可能地使用功能少的迭代器,以减少迭代器引入的副作用
  在7种STL容器的迭代器中,只有vector和deque的迭代器是随机访问迭代器,其他5种容器的迭代器均为双向迭代器
 前三种迭代器在此不再赘述

输出迭代器

输出流迭代器和输入流迭代器都需要包含头文件iterator

#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>
using namespace std;

int main(int argc, char *argv[])
{
    vector<int> ivec{1,3,4,3,5,2,52,5};
    ostream_iterator<int> osi(cout, " ");//定义一个输出流大迭代器
    copy(ivec.begin(), ivec.end(), osi);//将原有元素通过泛型算法拷贝到输出流中
    cout << endl;
    return 0;
}
输入迭代器
#include <iostream>
#include <iterator>
#include <vector>
#include <algorithm>
using namespace std;

int main(int argc, char *argv[])
{
    vector<int> ivec;
    istream_iterator<int> isi(cin);//定义一个输入流迭代器
    copy(isi, istream_iterator<int>(), back_inserter(ivec));//将输入数据插入到容器中
    for (auto const &item : ivec)
        cout << item << " ";
    cout << endl;
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值