名前空間
変種
操作

std::ranges::copy_n、std::ranges::copy_n_result

From cppreference.com
< cpp‎ | algorithm‎ | ranges
 
 
アルゴリズムライブラリ
制約付きアルゴリズムとRangeアルゴリズム (C++20)
制約付きアルゴリズム、例: ranges::copy, ranges::sort, ...
実行ポリシー (C++17)
シーケンスを変更しない操作
一括操作
(C++17)
検索操作
(C++11)                (C++11)(C++11)

シーケンスを変更する操作
コピー操作
(C++11)
(C++11)
スワップ操作
変換操作
生成操作
削除操作
順序変更操作
(C++17まで)(C++11)
(C++20)(C++20)
サンプリング操作
(C++17)

ソートおよび関連操作
パーティション操作
ソート操作
二分探索操作
(パーティション化された範囲)
集合操作 (ソート済み範囲)
マージ操作 (ソート済み範囲)
ヒープ操作
最小/最大操作
(C++11)
(C++17)
辞書順比較操作
順列操作
Cライブラリ
数値演算
未初期化メモリに対する操作
 
制約付きアルゴリズム
このメニューのすべての名前は名前空間 `std::ranges` に属します
シーケンスを変更しない操作
シーケンスを変更する操作
パーティション操作
ソート操作
二分探索操作 (ソート済み範囲)
       
       
集合操作 (ソート済み範囲)
ヒープ操作
最小/最大操作
       
       
順列操作
畳み込み操作
数値演算
(C++23)            
未初期化ストレージに対する操作
戻り値の型
 
ヘッダー <algorithm> で定義
呼び出しシグネチャ
template< std::input_iterator I, std::weakly_incrementable O >

requires std::indirectly_copyable<I, O>
constexpr copy_n_result<I, O>

    copy_n( I first, std::iter_difference_t<I> n, O result );
(1) (C++20以降)
ヘルパー型
template< class I, class O >
using copy_n_result = ranges::in_out_result<I, O>;
(2) (C++20以降)
1) rangeの先頭 first から range の先頭 result へ、整数 [0n) の各整数 i について *(result + i) = *(first + i) を実行して、ちょうど n 個の値をコピーします。 result[firstfirst + n) の範囲内にある場合、動作は未定義です(この場合、代わりに ranges::copy_backward が使用される可能性があります)。

このページで説明されている関数のようなエンティティは、アルゴリズム関数オブジェクト(非公式にはニーブロイドとして知られている)です。つまり、

目次

[edit] Parameters

first - コピー元の要素の範囲の開始位置
n - コピーする要素の数
結果 - コピー先範囲の先頭

[edit] Return value

ranges::copy_n_result{first + n, result + n}、またはより正式には、input_iterator ranges::next(first, n) に等しいイテレータと、weakly_incrementable ranges::next(result, n) に等しいイテレータを含む ranges::in_out_result 型の値。

[edit] Complexity

ちょうど n 回の代入。

[edit] Notes

実際には、std::ranges::copy_n の実装は、値の型が TriviallyCopyable で、イテレータ型が contiguous_iterator を満たす場合、複数の代入を回避し、std::memmove のようなバルクコピー関数を使用する場合があります。あるいは、コンパイラの最適化フェーズ中にそのようなコピー高速化が注入されることもあります。

重複する範囲をコピーする場合、std::ranges::copy_n は左方向へのコピー(宛先範囲の開始位置がソース範囲の外側にある場合)に適していますが、std::ranges::copy_backward は右方向へのコピー(宛先範囲の終了位置がソース範囲の外側にある場合)に適しています。

[edit] Possible implementation

struct copy_n_fn
{
    template<std::input_iterator I, std::weakly_incrementable O>
    requires std::indirectly_copyable<I, O>
    constexpr ranges::copy_n_result<I, O>
        operator()(I first, std::iter_difference_t<I> n, O result) const
    {
        for (; n-- > 0; (void)++first, (void)++result)
            *result = *first;
 
        return {std::move(first), std::move(result)};
    }
};
 
inline constexpr copy_n_fn copy_n{};

[edit] Example

#include <algorithm>
#include <iomanip>
#include <iostream>
#include <iterator>
#include <string>
#include <string_view>
 
int main()
{
    const std::string_view in{"ABCDEFGH"};
    std::string out;
 
    std::ranges::copy_n(in.begin(), 4, std::back_inserter(out));
    std::cout << std::quoted(out) << '\n';
 
    out = "abcdefgh";
    const auto res{std::ranges::copy_n(in.begin(), 5, out.begin())};
    const auto i{std::distance(std::begin(in), res.in)};
    const auto j{std::distance(std::begin(out), res.out)};
    std::cout << "in[" << i << "] = '" << in[i] << "'\n"
              << "out[" << j << "] = '" << out[j] << "'\n";
}

出力

"ABCD"
in[5] = 'F'
out[5] = 'f'

[edit] See also

要素の範囲を新しい場所にコピーする
(アルゴリズム関数オブジェクト)[編集]
要素の範囲を逆順にコピーする
(アルゴリズム関数オブジェクト)[編集]
特定の基準を満たす要素を除外して範囲をコピーする
(アルゴリズム関数オブジェクト)[編集]
特定の基準を満たす要素を別の値に置き換えながら範囲をコピーする
(アルゴリズム関数オブジェクト)[編集]
逆順になった範囲のコピーを作成する
(アルゴリズム関数オブジェクト)[編集]
要素の範囲をコピーして回転させる
(アルゴリズム関数オブジェクト)[編集]
連続する重複を含まない要素の範囲のコピーを作成する
(アルゴリズム関数オブジェクト)[編集]
要素の範囲を新しい場所にムーブする
(アルゴリズム関数オブジェクト)[編集]
要素の範囲を逆順で新しい場所にムーブする
(アルゴリズム関数オブジェクト)[編集]
(C++11)
指定された数の要素を新しい場所にコピーする
(関数テンプレート) [編集]
English 日本語 中文(简体) 中文(繁體)