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<<"";
}
相关文章
|
4月前
|
算法 编译器 C++
|
3天前
|
C++ 容器
STL—map容器
STL—map容器
|
2月前
|
存储 C++ 容器
C++之STL顺序容器
C++之STL顺序容器
|
3月前
|
算法 C++ 容器
c++迭代器介绍
C++中的迭代器是一种抽象的数据访问对象,它允许对容器中的元素进行遍历,而不必暴露底层数据结构的细节。迭代器提供了一种通用的方法来访问容器中的元素,无论容器的类型是什么。C++标准库中的许多容器(如vector、list、map等)都支持迭代器。
39 0
|
5月前
|
C++
【STL】:反向迭代器
【STL】:反向迭代器
26 0
|
11月前
|
C++ 容器
C++【STL】之反向迭代器
C++ STL 反向迭代器设计思想和模拟实现详细讲解,干货满满!
88 0
C++【STL】之反向迭代器
|
C++ 容器
C++ STL学习之【反向迭代器】
适配器模式是 STL 中的重要组成部分,在上一篇文章中我们学习了 容器适配器 的相关知识,即 stack 与 queue,除了 容器适配器 外,还有 迭代器适配器,借助 迭代器适配器,可以轻松将各种容器中的普通迭代器转变为反向迭代器,这正是适配器的核心思想
152 0
|
C语言 C++ 容器
STL迭代器
大部分ACM中使用的都是C/C++语言,但是说到C语言和C++语言的区别,却不知道。 C++语言用于竞赛真的是非常方便的,里面有很多函数还有STL这个好东西,比C语言方便,比其他语言好理解。
1314 0