std::valarray<T>::apply
Von cppreference.com
| valarray<T> apply( T func(T) ) const; |
||
| valarray<T> apply( T func(const T&) ) const; |
||
Gibt ein neues valarray gleicher Größe mit Werten zurück, die durch Anwendung der Funktion func auf die vorherigen Werte der Elemente erworben wurden.
Inhalt |
[bearbeiten] Parameter
| func | - | Anzuwendende Funktion für die Werte |
[bearbeiten] Rückgabewert
Das resultierende valarray mit Werten, die durch Anwendung der Funktion func erworben wurden.
[bearbeiten] Anmerkungen
Die Funktion kann mit einem anderen Rückgabetyp als std::valarray implementiert werden. In diesem Fall hat der Ersatztyp die folgenden Eigenschaften
- Alle const-Mitgliedsfunktionen von std::valarray sind vorhanden.
- std::valarray, std::slice_array, std::gslice_array, std::mask_array und std::indirect_array können aus dem Ersatztyp konstruiert werden.
- Für jede Funktion, die ein const std::valarray<T>& als Argument nimmt (außer begin() und end())(seit C++11), werden identische Funktionen hinzugefügt, die die Ersatztypen nehmen;
- Für jede Funktion, die zwei Argumente vom Typ const std::valarray<T>& annimmt, werden identische Funktionen hinzugefügt, die jede Kombination aus const std::valarray<T>& und Ersatztypen annehmen.
- Der Rückgabetyp fügt nicht mehr als zwei Ebenen von Template-Verschachtelung über den am tiefsten verschachtelten Argumenttyp hinaus hinzu.
[bearbeiten] Mögliche Implementierung
Einfache Implementierungen wie die folgenden können durch Expression Templates für höhere Effizienz ersetzt werden.
template<class T> valarray<T> valarray<T>::apply(T func(T)) const { valarray<T> other = *this; for (T& i : other) i = func(i); return other; } template<class T> valarray<T> valarray<T>::apply(T func(const T&)) const { valarray<T> other = *this; for (T& i : other) i = func(i); return other; } |
[bearbeiten] Beispiel
Berechnet und gibt die ersten 10 Fakultäten aus.
Führen Sie diesen Code aus
#include <cmath> #include <iostream> #include <valarray> 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'; }
Ausgabe
1 2 6 24 120 720 5040 40320 362880 3628800
[bearbeiten] Siehe auch
| wendet ein unäres Funktionsobjekt auf Elemente aus einem Bereich an (Funktion-Template) | |
| (C++20) |
wendet ein unäres Funktionsobjekt auf Elemente aus einem Bereich an (Algorithmus-Funktionsobjekt) |