C++ 参考手册

位置:首页 > C++ 参考手册 >数值库 >std::valarray > std::valarray<T>::cshift

valarray<T> cshift( int count ) const;

返回同大小的新 valarray ,其每个元素的位置被循环迁移 count 个元素。每个元素的新位置是 (i−count) mod s ,其中 i 为先前位置,而 s 为 size() 。

参数

count - 元素迁移的位置数

返回值

作为结果的 valarray ,拥有循环迁移的元素。

注意

函数能以不同于 std::valarray 的返回类型实现。此情况下,替换类型拥有下列属性:

  • 提供 std::valarray 的所有 const 成员函数。
  • 能从替换类型构造 std::valarray 、 std::slice_array 、 std::gslice_array 、 std::mask_array å’Œ std::indirect_array 。
  • 所有接受一个 const std::valarray& 类型参数的函数,除了 begin() å’Œ end() (C++11 èµ·)也应该接受替换类型。
  • 所有接受二个 const std::valarray& 类型参数的函数都应该接受 const std::valarray& 和替换类型的每种组合。
  • 返回类型添加不多于二层嵌套在最深层嵌套的参数类型上的模板。

示例

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

输出:

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

参阅

以填入零的方式移动 valarray 的元素
(公开成员函数)