注:从本文开始,此系列的文章将会把字数控制在合理的范围内:一是怕字数太多吓坏读者,二是在一篇文章中涉及太多的内容很难把问题详解,而且也不利于日后再次整理笔记。
/*
* transform(#include<algorithm>)的原型如下:
template<class InputIterator, class OutputIterator, class UnaryFunction>
OutputIterator transform(
InputIterator _First1, // 源容器的起始地址
InputIterator _Last1, // 源容器的终止地址
OutputIterator _Result, // 目标容器的起始地址
UnaryFunction _Func // 一元运算函数指针
);
template<class InputIterator1, class InputIterator2, class OutputIterator,
class BinaryFunction>
OutputIterator transform(
InputIterator1 _First1, // 源容器1的起始地址
InputIterator1 _Last1, // 源容器1的终止地址
InputIterator2 _First2, // 源容器2的起始地址,元素个数与1相同
OutputIterator _Result, // 目标容器的起始地址,元素个数与1相同
BinaryFunction _Func // 二元运算函数指针
);
*/
#include <iostream>
#include<algorithm>
#include<vector>
using namespace std;
int unary(int oprand)
{
return ++oprand;
}
int binary(int oprand1,int oprand2)
{
return oprand1+oprand2;
}
int main()
{
vector<int> vec1;
for(int i=0;i<5;i++)
vec1.push_back(i);
vector<int> vec2;
vec2.resize(vec1.size());// allocate space !!!目标容器必须预先设置一个大小大于等于vec1(源容器)(建议是相同 )
transform(vec1.begin(),vec1.end(),vec2.begin(),unary);
for(vector<int>::iterator it=vec2.begin();it!=vec2.end();it++)
{
cout<<*it<<'\t'; //输出1,2,3,4,5
}
cout<<endl;
vector<int> vec3;
vec3.resize(vec1.size());// allocate space !!!目标容器必须预先设置一个大小大于等于vec1(源容器)(建议是相同 )
transform(vec1.begin(),vec1.end(),vec2.begin(),vec3.begin(),binary);
for(vector<int>::iterator it=vec3.begin();it!=vec3.end();it++)
{
cout<<*it<<'\t'; //输出1,3,5,7,9
}
cout<<endl;
return 0;
}
运行结果: