Namensräume
Varianten
Aktionen

std::valarray<T>::shift

Von cppreference.com
< cpp‎ | numeric‎ | valarray
 
 
 
 
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

#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) [bearbeiten]