STL標(biāo)準(zhǔn)庫函數(shù)---std::transform()

  • std::transform在指定的范圍內(nèi)應(yīng)用于給定的操作,并將結(jié)果存儲在指定的另一個范圍內(nèi)。要使用std::transform函數(shù)需要包含<algorithm>頭文件。

以下是std::transform的兩個聲明,一個是對應(yīng)于一元操作,一個是對應(yīng)于二元操作:

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,

對于一元操作,將op應(yīng)用于[first1, last1)范圍內(nèi)的每個元素,并將每個操作返回的值存儲在以result開頭的范圍內(nèi)。給定的op將被連續(xù)調(diào)用last1-first1次。op可以是函數(shù)指針或函數(shù)對象或lambda表達式。

對于二元操作,使用[first1, last1)范圍內(nèi)的每個元素作為第一個參數(shù)調(diào)用binary_op,并以first2開頭的范圍內(nèi)的每個元素作為第二個參數(shù)調(diào)用binary_op,每次調(diào)用返回的值都存儲在以result開頭的范圍內(nèi)。給定的binary_op將被連續(xù)調(diào)用last1-first1次。binary_op可以是函數(shù)指針或函數(shù)對象或lambda表達式。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • STL--algorithm 一、非修改式序列算法 不需要使用循環(huán)而從序列中找出某些東西的基本工具,不改變?nèi)萜髦性?..
    ad丶leo閱讀 634評論 0 1
  • 空間配置器 分為第一級空間配置器,和第二級空間配置器 配合使用 第一級空間配置器分配大內(nèi)存大于128bytes...
    陳星空閱讀 1,397評論 0 1
  • 0.目錄 簡介 關(guān)系 介紹3.1 容器(Container)3.2 算法(Algorithm)3.3 迭代器(It...
    lllnan閱讀 1,031評論 0 1
  • transform知識點小結(jié) 一、來源與功能 來自 頭文件,對序列進行變換操作 二、使用方式 unary oper...
    書瓖果fifty閱讀 620評論 0 0
  • 算法 頭文件 (STL算法部分主要由頭文件,,組成。要使用STL中的算法函數(shù)必須包含頭文件,對于數(shù)值算法須包含,中...
    Wancho閱讀 667評論 0 1

友情鏈接更多精彩內(nèi)容