名前空間
変種

std::valarray<T>::shift

提供: cppreference.com
 
 
 
 
<tbody> </tbody>
valarray<T> shift( int count ) const;

位置が要素 count 個分シフトされた要素を持つ同じサイズの新しい valarray を返します。 それぞれの要素の新しい位置は i−count です。 ただし i は以前の位置です。 シフトされた要素の値は T() になります。

引数

count - 要素をシフトする位置の数

戻り値

シフトされた要素を持つ結果の valarray。

ノート

関数は std::valarray と異なる戻り値の型を使用して実装することができます。 この場合、その置換型は以下の性質を持ちます。

  • std::valarray のすべての const メンバ関数が提供されます。
  • 置換型から std::valarraystd::slice_arraystd::gslice_arraystd::mask_array および std::indirect_array が構築できます。
  • const std::valarray& 型の引数を取るすべての関数 ( begin()end() を除く) (C++11以上) は置換型も受理するべきです。
  • const std::valarray& 型の引数を2つ取るすべての関数は const std::valarray& と置換型のすべての組み合わせを受理するべきです。
  • 戻り値の型は最も深くネストした引数型より3段以上ネストしたテンプレートを追加しません。

#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";
}

出力:

1 2 3 4 5 6 7 8 
3 4 5 6 7 8 0 0

関連項目

valarray の要素を循環シフトします
(パブリックメンバ関数) [edit]