算法简介:
for_each //遍历容器
transform //搬运容器到另一个容器中
一、for_each:实现遍历容器
函数原型:
for_each(iterator beg, iterator end, _func);
// 遍历算法 遍历容器元素
// beg 开始迭代器
// end 结束迭代器
// _func 函数或者函数对象
代码示例:
#include<iostream>
using namespace std;
#include<vector>
#include<algorithm>
//普通函数
void print01(int val)
{
cout << val << " ";
}
//仿函数
class print02
{
public:
void operator()(int val)
{
cout << val << " ";
}
};
void test()
{
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());//仿函数放函数对象,加小括号
}
int main()
{
test();
return 0;
}
总结:for_each在实际开发中是最常用遍历算法,需要熟练掌握
二、transform:搬运容器到另一个容器中
函数原型:
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;
//return v + 100;
}
};
class MyPrint
{
public:
void operator()(int val)
{
cout << val << " ";
}
};
void test()
{
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());
}
int main()
{
test();
return 0;
}
总结: 搬运的目标容器必须要提前开辟空间,否则无法正常搬运