c++STL之常用遍历算法

需要引入头文件#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;
    利用仿函数
 endl;
}


 main() {
    test();
    system("pause);
    return 0;
}

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

#include<iostream>
 Transform {
int {
        这里可以对val进行一些判断
        return val;
    }    
};
 {
        cout << val << ;
    }
};

)
    {
        v1.push_back(i);
    }
    vector< v2;
    目标容器需要先开辟空间
    v2.resize(v1.size());
    transform(v1.begin(),v2.begin(),Transform());
    for_each(v2.begin(),v2.end(),1)">;
}

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...