std::valarray<T>::cshift

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

返回大小相同的新 valarray,它的每个元素的位置被循环迁移 count 个元素。

非负 count 值会将元素向左循环迁移 count 个位置,负 count 值会将元素向右循环迁移 -count 个位置。

参数

count - 元素迁移的位置数

返回值

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

注意

函数能实现为拥有 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

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 618 C++98 表示迁移后元素的表达式在 size()0 的情况下会包含除零操作 不使用表达式表示迁移后的位置

参阅

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