黑马程序员C++提高14——常用的遍历算法【for_each、transform】

在这里插入图片描述

#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;
}

猜你喜欢

转载自blog.csdn.net/qq_43685399/article/details/108611344