名前空間
変種

std::valarray<T>::apply

提供: cppreference.com
 
 
 
 
<tbody> </tbody>
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::valarraystd::slice_arraystd::gslice_arraystd::mask_array および std::indirect_array が構築できます。
  • const std::valarray& 型の引数を取るすべての関数 ( begin()end() を除く) (C++11以上) は置換型も受理するべきです。
  • const std::valarray& 型の引数を2つ取るすべての関数は const std::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個の階乗を計算して表示します。

#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 {
                    return std::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

関連項目

指定範囲の要素に関数を適用します
(関数テンプレート) [edit]