我不太懂的STL(学到老活到老)
作者:互联网
STL 的一些用法
在工程实践中,总是能看到新的未曾了解过的STL函数或用法。每次都得重新查阅,比较麻烦。将一些不懂的内容记录下来,以备时时翻阅
std::transform
参考链接:https://blog.csdn.net/fengbingchun/article/details/63252470
transform() 可以将函数应用到制定的范围内,并将这个函数返回的值保存到另一个序列中,它返回的迭代器指向输出序列所保存的最后一个元素的下一个位置。
源码:
以下是std::transform的两个声明,一个是对应于一元操作,一个是对应于二元操作。
template <class InputIterator, class OutputIterator, class UnaryOperation>
OutputIterator transform (InputIterator first1, InputIterator last1,
OutputIterator result, UnaryOperation op);
template <class InputIterator1, class InputIterator2,
class OutputIterator, class BinaryOperation>
OutputIterator transform (InputIterator1 first1, InputIterator1 last1,
InputIterator2 first2, OutputIterator result,
BinaryOperation binary_op);
对于一元操作,将op应用于[first1, last1)范围内的每个元素,并将每个操作返回的值存储在以result开头的范围内。给定的op将被连续调用last1-first1次。op可以是函数指针或函数对象或lambda表达式。
对于二元操作,使用[first1, last1)范围内的每个元素作为第一个参数调用binary_op,并以first2开头的范围内的每个元素作为第二个参数调用binary_op,每次调用返回的值都存储在以result开头的范围内。给定的binary_op将被连续调用last1-first1次。binary_op可以是函数指针或函数对象或lambda表达式。
实例:
//一元: 将[first1, last1)范围内的每个元素加5,然后依次存储到result中
int op_increase(int i) {return (i + 5)};
std::transform(first1, last1, result, op_increase);
//二元:将first1和first2开头的范围内的每个元素相加,然后依次存储到result中。
int op_add(int, a, int b) {return (a + b)};
std::transform(first1, last1, first2, result, op_add);
标签:活到老,学到老,STL,transform,int,last1,result,first1,op 来源: https://www.cnblogs.com/wiesslibrary/p/16351137.html