C++系列内容的学习目录 → \rightarrow →C++学习系列内容汇总。
<algorithm>
、 <functional>
、<numeric>
组成;<algorithm>
是所有STL头文件中最大的一个,范围涉及到比较、 交换、查找、遍历操作、复制、修改等等;<numeric>
体积很小,只包括几个在序列上面进行简单数学运算的模板函数;<functional>
定义了一些模板类,用以声明函数对象。学习目标: 掌握常用的遍历算法。
算法简介:
for_each
//遍历容器transform
//搬运容器到另一个容器中功能描述: 实现遍历容器。
函数原型:for_each(iterator beg, iterator end, _func);
// 遍历算法,遍历容器元素
// beg 开始迭代器
// end 结束迭代器
// _func 函数或者函数对象
实例如下所示。
#include<iostream> using namespace std; #include<vector> #include<algorithm> //常用遍历算法:for_each //普通函数 void print01(int val) { cout << val << " "; } //仿函数 class print02 { public: void operator()(int val) { cout << val << " "; } }; void test01() { vector<int>v; for (int i = 0; i < 10; i++) { v.push_back(i); } for_each(v.begin(), v.end(), print01); //普通函数将函数名放入 cout << endl; for_each(v.begin(), v.end(), print02()); //仿函数将函数对象放入 cout << endl; } int main() { test01(); system("pause"); return 0; }
0 1 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9
总结: for_each在实际开发中是最常用遍历算法,需要熟练掌握。
功能描述: 搬运容器到另一个容器中。
函数原型:transform(iterator beg1, iterator end1, iterator beg2, _func);
// beg1 源容器开始迭代器
// end1 源容器结束迭代器
// beg2 目标容器开始迭代器
// _func 函数或者函数对象
实例如下所示。
#include<iostream> using namespace std; #include<vector> #include<algorithm> //常用遍历算法:transform //仿函数 class Transform { public: int operator()(int v) { return v + 100; //搬运过程中可以修改值 } }; class MyPrint { public: void operator()(int val) { cout << val << " "; } }; void test01() { vector<int>v; for (int i = 0; i < 10; i++) { v.push_back(i); } vector<int>vTarget; //目标容器 vTarget.resize(v.size()); //目标容器需要提前开辟空间 transform(v.begin(), v.end(), vTarget.begin(), Transform()); for_each(vTarget.begin(), vTarget.end(), MyPrint()); cout << endl; } int main() { test01(); system("pause"); return 0; }
100 101 102 103 104 105 106 107 108 109
总结: 搬运的目标容器必须要提前开辟空间,否则无法正常搬运。