std::valarray<T>::shift
Von cppreference.com
| valarray<T> shift( int count ) const; |
||
Gibt ein neues valarray gleicher Größe zurück, bei dem die Elemente um count Positionen verschoben sind. Die neue Position jedes Elements ist i−count, wobei i die vorherige Position ist. Der Wert der "eingeschobenen" Elemente ist T().
Inhalt |
[bearbeiten] Parameter
| zählt | - | Anzahl der Positionen, um die die Elemente verschoben werden sollen |
[bearbeiten] Rückgabewert
Das resultierende valarray mit verschobenen Elementen.
[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] Beispiel
Führen Sie diesen Code aus
#include <iostream> #include <valarray> int main() { std::valarray<int> v{1, 2, 3, 4, 5, 6, 7, 8}; for (auto const& val : v) std::cout << val << ' '; std::cout << '\n'; std::valarray<int> v2 = v.shift(2); for (auto const& val : v2) std::cout << val << ' '; std::cout << '\n'; }
Ausgabe
1 2 3 4 5 6 7 8 3 4 5 6 7 8 0 0
[bearbeiten] Siehe auch
| zyklische Verschiebung der Elemente des valarray (öffentliche Memberfunktion) |