您的位置:首页 > 编程语言 > C语言/C++

C++语法基础--泛型算法(generic algorithm)--transform

2013-07-03 11:59 375 查看
注:从本文开始,此系列的文章将会把字数控制在合理的范围内:一是怕字数太多吓坏读者,二是在一篇文章中涉及太多的内容很难把问题详解,而且也不利于日后再次整理笔记。

/*

* 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;

}


运行结果:




内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: