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

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




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


运行结果:


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值