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;
}
运行结果:
/*
* 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;
}
运行结果:
相关文章推荐
- C++语法基础--泛型算法(generic algorithm)--对容器排序的算法sort(),stable_sort(),unique()
- C++语法基础--泛型算法(generic algorithm)--replace_copy(),unique_copy,copy()
- C++语法基础--泛型算法(generic algorithm)--iostream迭代器
- C++语法基础--泛型算法(generic algorithm)--插入迭代器back_inserter(),front_insertor(),inserter()以及next()函数简介
- C++语法基础--泛型算法(generic algorithm)--find(),find_if()
- C++语法基础--泛型算法(generic algorithm)--只读算法accumulate(),find_first_of(),count(),count_if()
- C++语法基础--泛型算法(generic algorithm)--写入容器元素的算法fill(),fill_n,replace()
- C++语法基础--泛型算法(generic algorithm)--反向迭代器,reverse_iterator::base()
- C++:泛型算法基础
- C++泛型算法中的accumulate
- 3 算法训练 乘法表(基础题) C++
- C++ 泛型算法unique 和unique_copy :删除相邻的重复元素
- C++学习笔记28——泛型算法之iostream迭代器
- (基础)C++语法_1
- C++ Simplify01-基础语法
- 心动C++ 情牵基础算法 II
- C++学习笔记(一) 补充篇 基础语法 — 参考慕课网 值得推荐!
- C++ 泛型基础
- c++ 基础语法(逐渐补充)
- C/C++_lesson1_C++语法基础