C++ transform 浅析
【摘要】
transform,一個(gè)區(qū)間元素交換函數(shù)。該函數(shù)用于實(shí)現(xiàn)容器元素的變換操作。有例如以下兩個(gè)使用原型,一個(gè)將迭代器區(qū)間[first。last)中元素。運(yùn)行一元函數(shù)(有一個(gè)輸入變量)對(duì)象op操作。交換后的結(jié)果放在[result,result+(last-first))區(qū)間中。還有一個(gè)將迭代器區(qū)間[first1,last1)的元素*i,依次與[first2,first2+(last-first))的元素*j,運(yùn)行二元函數(shù)(有兩個(gè)輸入變量)操作binary_op(*i,*j)。交換結(jié)果放在[result,result+(last1-first1))。
【正文】 ? ?
?函數(shù)原型:
template < class InputIterator, class OutputIterator, class UnaryOperator > OutputIterator transform ( InputIterator first1, InputIterator last1, OutputIterator result, UnaryOperator op );
參數(shù)說(shuō)明:
first1, last1?
指出要進(jìn)行元素變換的第一個(gè)迭代器區(qū)間 [first1,last1)。?
first2?
指出要進(jìn)行元素變換的第二個(gè)迭代器區(qū)間的首個(gè)元素的迭代器位置,該區(qū)間的元素個(gè)數(shù)和第一個(gè)區(qū)間相等。?
result?
指出變換后的結(jié)果存放的迭代器區(qū)間的首個(gè)元素的迭代器位置?
op?
用一元函數(shù)對(duì)象op作為參數(shù),運(yùn)行其后返回一個(gè)結(jié)果值。
它能夠是一個(gè)函數(shù)或?qū)ο髢?nèi)的類重載operator()。
?
binary_op?
用二元函數(shù)對(duì)象binary_op作為參數(shù)。運(yùn)行其后返回一個(gè)結(jié)果值。它能夠是一個(gè)函數(shù)或?qū)ο髢?nèi)的類重載operator()。
程序演示樣例:
#include <iostream> #include <algorithm> #include <vector> using namespace std; int op_increase (int i) { return ++i; } int op_sum (int i, int j) { return i+j; } int main () { vector<int> first; vector<int> second; vector<int>::iterator it; // set some values: for (int i=1; i<6; i++) first.push_back (i*10); // first: 10 20 30 40 50 second.resize(first.size()); // allocate space transform (first.begin(), first.end(), second.begin(), op_increase); // second: 11 21 31 41 51 transform (first.begin(), first.end(), second.begin(), first.begin(), op_sum); // first: 21 41 61 81 101 cout << "first contains:"; for (it=first.begin(); it!=first.end(); ++it) cout << " " << *it; cout << endl; return 0; }
轉(zhuǎn)載于:https://www.cnblogs.com/jzdwajue/p/6917588.html
與50位技術(shù)專家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的C++ transform 浅析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linux下添加用户并赋予root权限
- 下一篇: Git中.gitignore文件的使用