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::valarray、
std::slice_array、std::gslice_array、std::mask_arrayおよびstd::indirect_arrayが構築できます。 const std::valarray&型の引数を取るすべての関数 ( begin() と end() を除く) (C++11以上) は置換型も受理するべきです。const std::valarray&型の引数を2つ取るすべての関数はconst std::valarray&と置換型のすべての組み合わせを受理するべきです。- 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。
- std::valarray のすべての
実装例
以下の愚直な実装はより高い効率を求めて式テンプレートに置き換えることができます。
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 {
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
関連項目
| 指定範囲の要素に関数を適用します (関数テンプレート) |