std::valarray<T>::apply
提供: cppreference.com
valarray<T> apply( T func(T))const; | ||
valarray<T> apply( T func(const T&))const; | ||
要素の以前の値に関数 func
を適用することによって取得された値を持つ同じサイズの新しい valarray を返します。
目次 |
[編集]引数
func | - | 値に適用する関数 |
[編集]戻り値
関数 func
を適用することによって取得された値を持つ結果の valarray。
[編集]ノート
関数は std::valarray と異なる戻り値の型を使用して実装することができます。 この場合、その置換型は以下の性質を持ちます。
- std::valarray のすべての const メンバ関数が提供されます。
- 置換型から std::valarray、 std::slice_array、 std::gslice_array、 std::mask_array および std::indirect_array が構築できます。
- conststd::valarray& 型の引数を取るすべての関数 ( begin() と end() を除く)(C++11以上) は置換型も受理するべきです。
- conststd::valarray& 型の引数を2つ取るすべての関数は conststd::valarray& と置換型のすべての組み合わせを受理するべきです。
- 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。
[編集]実装例
以下の愚直な実装はより高い効率を求めて式テンプレートに置き換えることができます。
template<class T> valarray<T> valarray<T>::apply( T func(T))const{ valarray<T> copy =*this;for(T &i : other){ i = func(i);}return copy;} template<class T> valarray<T> valarray<T>::apply( T func(const T&))const{ valarray<T> copy =*this;for(T &i : other){ i = func(i);}return copy;} |
[編集]例
最初の10個の階乗を計算して表示します。
Run this code
#include <iostream>#include <valarray>#include <cmath> int main(){std::valarray<int> v ={1,2,3,4,5,6,7,8,9,10}; v = v.apply([](int n)->int{returnstd::round(std::tgamma(n+1));});for(auto n : v){std::cout<< n <<' ';}std::cout<<'\n';}
出力:
1 2 6 24 120 720 5040 40320 362880 3628800
[編集]関連項目
指定範囲の要素に関数を適用します (関数テンプレート) |