Namensräume
Varianten
Aktionen

std::valarray<T>::cshift

Von cppreference.com
< cpp‎ | numeric‎ | valarray
 
 
 
 
valarray<T> cshift( int count ) const;

Gibt ein neues valarray gleicher Größe zurück, dessen Elemente um count Positionen zirkulär verschoben sind.

Ein nicht-negativer Wert von count verschiebt die Elemente um count Positionen nach links, und ein negativer Wert von count verschiebt die Elemente um -count Positionen nach rechts.

Inhalt

[bearbeiten] Parameter

zählt - Anzahl der Positionen, um die die Elemente verschoben werden sollen

[bearbeiten] Rückgabewert

Das resultierende valarray mit zirkulär verschobenen Elementen.

[bearbeiten] Hinweise

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.cshift(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 1 2

[bearbeiten] Fehlerberichte

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 618 C++98 der Ausdruck der verschobenen Elemente
enthält eine Division durch Null, wenn size() 0 ist
beschreibt die neuen Positionen
ohne Verwendung von Ausdrücken

[bearbeiten] Siehe auch

Null-auffüllende Verschiebung der Elemente des valarray
(public member function) [bearbeiten]