STL迭代器

简介: STL迭代器

迭代器的基本原理

  • 迭代器是一个"可遍历STL容器内部分或全部元素"的对象
  • 迭代器指出容器中的一个特定位置
  • 迭代器就如同一个指针
  • 迭代器提供对一个容器中的对象的访问方法,并且可以定义容器中对象的范围
  • 迭代器就像一个指针

迭代器的分类

输入迭代器:

又称为"只读迭代器",它从容器中读取元素,只能一次读入一个元素向前移动,只支持一遍算法,同一个输入迭代器不能两遍遍历一个序列

输出迭代器:

又称为"只写迭代器",它往容器中写入元素,只能一次写入一个元素向前移动,同一个输出迭代器不能两边遍历一个序列。

正向迭代器:

组合输入迭代器和输出迭代器的功能,还可以多次解析一个迭代器指定位置,可以对一个值进行多次读/写

双向迭代器:

组合正向迭代器的功能,还可以通过操作符向后移动位置

随机访问迭代器:

组合双向迭代器的功能,还可以向前向后跳过任意个位置,可以直接访问容器中任何位置的元素

双向迭代只能一步一步的走,随机迭代器可以跨很多步走

vector与迭代器的配合使用

vector<int>  vecInt;                //假设包含1,3,5,7,9元素

vector<int>::iterator it;            //声明容器vector<int>迭代器

it = vecInt.begin();

it++  it+=2....

//正向遍历
vector<int> vecInt;
for(vector<int>::iterator it=vecInt.begin();it!=vecInt.end();++it)
{
    int tmp = *it;
    cout<<tmp<<"\t";
}
//逆向遍历
for(vector<int>::reverse_iterator it=vecInt.rbegin();it!=vecInt.rend(),++it)
{
    int tmp;
    cout<<tmp<<"\t";
}

deque容器与迭代器

deque.begin();                                //返回容器中第一个元素的迭代器

deque.end();                                   //返回容器中最后一个元素之后的迭代器

deque.rbegin();                               //返回容器中倒数第一个元素的迭代器

deque.rend();                                  //返回容器中倒数最后一个元素之后的迭代器

for(deque<int>::iterator it=deqInt.begin();it!=deqInt.end(),++it)
{
    cout<<*it;
    cout<<"";
}
for(deque<int>::reverse_iterator rit=deqInt.rbegin();rit!=deque.rend();++rit)
{
    cout<<*rit;
    cout<<"";
}
相关文章
|
XML Java 数据格式
Spring 的自动装配?有哪些方式?
Spring 的自动装配?有哪些方式?
229 0
|
机器学习/深度学习 人工智能 自然语言处理
人工智能的技术变革:HMS Core 让你也拥有《星球大战》中的机器人
你还记得《星球大战》电影中的礼仪机器人 C-3PO 吗?就是那个承担着不同种族、不同物种间翻译交流作用的礼仪机器人。C-3PO 通过从数据库中下载资料来更新自己的语言技能,精通 700 万种语言交流形式,可以说是对宇宙间的所有已知语言尽数掌握。
578 0
人工智能的技术变革:HMS Core 让你也拥有《星球大战》中的机器人
SpringMVC之使用 @RequestMapping 映射请求
SpringMVC之使用 @RequestMapping 映射请求
184 0
|
机器学习/深度学习 算法 搜索推荐
场景导购系列一:个性化服饰搭配在淘宝搜索的实践
本文描述了使用深度学习算法在淘宝环境中怎么给用户提供个性化服饰搭配的一些探索。
6190 0
|
Go 图形学
Unity插件扩展中组件常用的几个方法
最近为美术编写一个Unity编辑器的扩展,主要为了减轻美术在修改预制对象时的机械化操作的繁琐和出错。具体实现的几个功能: 1、删除指定组件; 2、复制、粘贴指定的组件; 3、重新关联新的属性; 4、重新保存预制对象;   一、删除指定类型的组件 public static void RemoveCo...
1573 0
|
17小时前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
10天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~