c++ STL常用遍历算法

时间:2021-05-20

需要引入头文件#include<algorithm>

1.for_each

#include<iostream>using namespace std;#include <vector>#include <algorithm>class MyPrint {public: void operator()(int val) const{ cout << val << " "; } };void printVector(int val) { cout << val << " ";}void test() { vector<int> v1; for (int i = 0; i < 10; i++) { v1.push_back(i); } //利用普通函数 for_each(v1.begin(), v1.end(), printVector); cout << endl; //利用仿函数 for_each(v1.begin(), v1.end(), MyPrint()); cout << endl;}int main() { test(); system("pause"); return 0;}

2.transform:将容器搬运到另一个容器中

#include<iostream>using namespace std;#include <vector>#include <algorithm>class Transform {public: int operator()(int val) const{ //这里可以对val进行一些判断 return val; } };class MyPrint {public: void operator()(int val) const { cout << val << " "; }};void test() { vector<int> v1; for (int i = 0; i < 10; i++) { v1.push_back(i); } vector<int> v2; //目标容器需要先开辟空间 v2.resize(v1.size()); transform(v1.begin(), v1.end(), v2.begin(), Transform()); for_each(v2.begin(), v2.end(), MyPrint()); cout << endl;}int main() { test(); system("pause"); return 0;}

以上就是c++ STL常用遍历算法的详细内容,更多关于c++ 遍历算法的资料请关注其它相关文章!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章