1 迭代器 Iterators

5种迭代器类型

  1. 随机访问迭代器: vector, deque, array
// 允许的操作
vector<int> itr;
itr = itr + 5; // itr往前移5步
itr = itr - 4;
if (itr2 > itr1) ...
++itr; // 前置的比后置的快
--itr;
  1. 双向迭代器: list, set/multiset, map/multimap
// 允许的操作
list<int> itr;
++itr;
--itr;
  1. 前向迭代器: forward_list
// 只允许++操作
forward_list<int> itr;
++itr; // 无序容器“至少”提供前向迭代器
  1. 输入迭代器: 前向,只能从迭代器读取
int x = *itr;
  1. 输出迭代器: 前向,只能写到迭代器
*itr = 100;

const_iterator

// 每个容器都有iterator和const_iterator
set<int>::iterator itr;
set<int>::const_iterator citr; // 只读访问 set<int> myset = {2,4,5,1,9};
for (citr = myset.begin(); citr != myset.end(); ++citr) {
cout << *citr << endl;
//*citr = 3;
}
for_each(myset.cbegin(), myset.cend(), MyFunction); // Only in C++ 11

2 迭代器函数:

advance(itr, 5);       // itr往前移5步   itr += 5;
distance(itr1, itr2); // 策测量itr1和itr2之间距离

迭代器适配器(预定义迭代器)

  • 一种特殊且更强大的迭代器

    1. Insert iterator
    2. Stream iterator
    3. Reverse iterator
    4. Move iterator (C++ 11)
  1. 插入迭代器 Insert Iterator:
vector<int> vec1 = {4,5};
vector<int> vec2 = {12, 14, 16, 18};
vector<int>::iterator it = find(vec2.begin(), vec2.end(), 16);
insert_iterator< vector<int> > i_itr(vec2,it);
copy(vec1.begin(),vec1.end(), // 源
i_itr); // 目的
//vec2: {12, 14, 4, 5, 16, 18}
// 其他的插入迭代器: back_insert_iterator, front_insert_iterator
  1. 流迭代器 Stream Iterator:
vector<string> vec4;
copy(istream_iterator<string>(cin), istream_iterator<string>(),
back_inserter(vec4)); copy(vec4.begin(), vec4.end(), ostream_iterator<string>(cout, " ")); // 更简洁的写法:
copy(istream_iterator<string>(cin), istream_iterator<string>(),
ostream_iterator<string>(cout, " "));
  1. 反向迭代器 Reverse Iterator:
vector<int> vec = {4,5,6,7};
reverse_iterator<vector<int>::iterator> ritr;
for (ritr = vec.rbegin(); ritr != vec.rend(); ritr++)
cout << *ritr << endl; // prints: 7 6 5 4
  1. 移动迭代器 Move Iterator:
int main () {
std::vector<std::string> foo (3);
std::vector<std::string> bar {"one","two","three"}; typedef std::vector<std::string>::iterator Iter; std::copy ( std::move_iterator<Iter>(bar.begin()),
std::move_iterator<Iter>(bar.end()),
foo.begin() ); // bar now contains unspecified values; clear it:
bar.clear(); std::cout << "foo:";
for (std::string& x : foo) std::cout << ' ' << x;
std::cout << '\n'; return 0;
}

算法 Algorithms

 *   - 大部分是循环
* 当你的代码中出现循环的时候,可以考虑是不是能用STL算法
*/
vector<int> vec = { 4, 2, 5, 1, 3, 9};
vector<int>::iterator itr = min_element(vec.begin(), vec.end()); // itr -> 1 // 注1: 算法总是在半开区间上处理: [begin, end)
sort(vec.begin(), itr); // vec: { 2, 4, 5, 1, 3, 9} reverse(itr, vec.end()); // vec: { 2, 4, 5, 9, 3, 1} itr => 9 // 注2: 算法总是假设目的地有足够的空间
vector<int> vec(3);
copy(itr, vec.end(), // Source
vec2.begin()); // Destination
//vec2至少要有3个元素的空间 // 注3: 大部分情况下使用成员函数版本
vector<int> vec3;
copy(itr, vec.end(), back_inserter(vec3)); // 插入而不是覆写
// 返回back_insert_iterator,每次只插入一个,低效 vec3.insert(vec3.end(), itr, vec.end()); // 高效且安全 // 注4: 算法和函数
bool isOdd(int i) {
return i%2;
} int main() {
vector<int> vec = {2, 4, 5, 9, 2}
vector<int>::iterator itr = find_if(vec.begin(), vec.end(), isOdd);
// itr -> 5
} // 注5: 算法和原生C++数组
int arr[4] = {6,3,7,4};
sort(arr, arr+4);

STL基础--迭代器和算法的更多相关文章

  1. STL(标准模板库)理论基础,容器,迭代器,算法

    基本概念 STL(Standard Template Library,标准模板库)是惠普实验室开发的一系列软件的统称.现然主要出现在C++中,但在被引入C++之前该技术就已经存在了很长的一段时间.   ...

  2. STL理论基础、容器、迭代器、算法

    一.STL基本概念 STL(Standard Template Library,标准模板库)是惠普实验室开发的一系列软件的统称.现然主要出现在C++中,但在被引入C++之前该技术就已经存在了很长的一段 ...

  3. stl中的容器、迭代器和算法----vector中的find实现

    来源 http://blog.csdn.net/huangyimin/article/details/6133650 stl包括容器.迭代器和算法: 容器 用于管理一些相关的数据类型.每种容器都有它的 ...

  4. stl之容器、迭代器、算法几者之间的关系

    转自:https://blog.csdn.net/bobodem/article/details/49386131 stl包括容器.迭代器和算法: 容器 用于管理一些相关的数据类型.每种容器都有它的优 ...

  5. STL的迭代器和类型萃取

    今天就可以把STL库中迭代器的实现,和类型萃取好好整理一下了 迭代器的设计思维是STL的关键所在,在STL的实际运用和泛型思维,迭代器都扮演着十分重要的角色,STL力求把数据容器和算法的概念分开来,于 ...

  6. STL六大组件之——算法小小小小的解析

    参考自侯捷的<stl源码剖析> stl算法主要分为非可变序列算法(指不直接修改其所操作的容器内容的算法),可变序列算法(指可以修改它们所操作的容器内容的算法),排序算法(包括对序列进行排序 ...

  7. STL中的所有算法(70个)

    STL中的所有算法(70个)----9种类型(略有修改by crazyhacking) 参考自: http://www.cppblog.com/mzty/archive/2007/03/14/1981 ...

  8. 带你深入理解STL之迭代器和Traits技法

    在开始讲迭代器之前,先列举几个例子,由浅入深的来理解一下为什么要设计迭代器. //对于int类的求和函数 int sum(int *a , int n) { int sum = 0 ; for (in ...

  9. STL之迭代器(iterator)

    1 头文件 所有容器有含有其各自的迭代器型别(iterator types),所以当你使用一般的容器迭代器时,并不需要含入专门的头文件.不过有几种特别的迭代器,例如逆向迭代器,被定义于<iter ...

随机推荐

  1. JavaBasic_09

    方法的参数传递 方法调用时参数值的传递可以分为"值传递"和"引用传递"两种 值传递 - a.当方法的参数为基本数据类型时 b.实参的值被复制给形参,改变形参不会 ...

  2. JAVA基础部分复习(二、集合类型)

    对于这些常用的集合,建议还是需要先了解一下底层实现原理,这样在不同的使用场景下才能选择更好的方案. Set介绍以及对比,常用方法: package cn.review.day02; import ja ...

  3. [LeetCode&Python] Problem 283. Move Zeroes

    Given an array nums, write a function to move all 0's to the end of it while maintaining the relativ ...

  4. com.sun.org.apache.xerces.internal.impl.dv.util.Base64出现的问题

    import com.sun.org.apache.xerces.internal.impl.dv.util.Base64; 出现的问题是这个在eclipse中无法使用,解决方法如下: (1)进入ec ...

  5. ajax遍历数组对象

    success: function(data){ console.log(data); for (var warn in data) { alert(data[warn].kh_lxr); } } d ...

  6. rsync命令

    1.rsync命令(文件同步工具,可以理解为动态备份): rsync是linux系统下的数据镜像备份工具.使用快速增量备份工具Remote Sync可以远程同步,支持本地复制,或者与其他SSH.rsy ...

  7. linux rpm yum 安装 软件

    rpm 安装: 1.rpm包的了解:  rpm  安装  升级  删除 rpm -ivh  ****.rpm   安装 rpm -Uvh  ****.rpm  升级 rpm -e name    删除 ...

  8. 【Wannafly挑战赛24】【C失衡天平】

    https://www.nowcoder.com/acm/contest/186/C 题意:有n个武器,每个武器都有一个重量 Wi,有一个天平,只要两端的重量差不大于m就能达到平衡,求在天平平衡的情况 ...

  9. 《DSP using MATLAB》Problem 5.36

    第1小题 代码: %% ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ ...

  10. Python知识点整理,基础4 - 集合操作