#include<vector> //向量容器vector
#include<algorithm> //算法的头文件
#include<iostream>
using namespace std;
//for_each 和 transform 算法
//供transform用的一元函数对象(仿函数)
struct MyPlus {
int operator()(int val) {
return val + 100;
}
};
//供for_each用的输出规则
void MyPrint(int val) {
cout << val << " ";
}
void test01() {
vector<int> v1;
vector<int> v2;
for (int i = 0; i < 6; i++) {
v1.push_back(i);
}
//在v2中放入元素时,一定要使用resize初始化足够的空间
//不能用reserve开辟容量,因为这个方法不会初始化
v2.resize(v1.size());
//transform算法 将一个容器的元素搬运到另一个容器中
//v2中存放的数据是MyPlus返回的数据
transform(v1.begin(), v1.end(), v2.begin(), MyPlus());
//for_each算法 按规则遍历容器中的元素
cout << "v1:";
for_each(v1.begin(), v1.end(), MyPrint);
cout << "\nv2:";
for_each(v2.begin(), v2.end(), MyPrint);
}
//简单测试
int main() {
test01();
cout << endl << endl;
return 0;
}
黑马程序员C++提高14——常用的遍历算法【for_each、transform】
猜你喜欢
转载自blog.csdn.net/qq_43685399/article/details/108611344
今日推荐
周排行