std:: rotate_copy
|
ヘッダー
<algorithm>
で定義
|
||
|
template
<
class
ForwardIt,
class
OutputIt
>
OutputIt rotate_copy
(
ForwardIt first, ForwardIt middle,
|
(1) | (constexpr since C++20) |
|
template
<
class
ExecutionPolicy,
class
ForwardIt1,
class
ForwardIt2
>
|
(2) | (since C++17) |
[
first
,
last
)
の
左回転
を
d_first
にコピーします。
[
first
,
last
)
の要素を、
d_first
から始まる宛先範囲にコピーする。このとき、宛先範囲では
[
middle
,
last
)
の要素の後に
[
first
,
middle
)
の要素が配置され、両範囲の要素の順序は保持される。
|
std:: is_execution_policy_v < std:: decay_t < ExecutionPolicy >> が true であること。 |
(C++20まで) |
|
std:: is_execution_policy_v < std:: remove_cvref_t < ExecutionPolicy >> が true であること。 |
(C++20以降) |
以下のいずれかの条件が満たされる場合、動作は未定義です:
-
[first,middle)または[middle,last)が 有効な範囲 ではない。 - ソースと宛先の範囲が重複している。
目次 |
パラメータ
| first, last | - | コピーする要素のソース 範囲 を定義するイテレータのペア |
| middle | - |
新しい範囲の先頭に現れるべき
[
first
,
last
)
内の要素へのイテレータ
|
| d_first | - | 宛先範囲の先頭 |
| policy | - | 使用する 実行ポリシー |
| 型要件 | ||
-
ForwardIt, ForwardIt1, ForwardIt2
は
LegacyForwardIterator
の要件を満たさなければならない
|
||
-
OutputIt
は
LegacyOutputIterator
の要件を満たさなければならない
|
||
戻り値
コピーされた最後の要素の次の要素を指す出力イテレータ。
計算量
正確に std:: distance ( first, last ) 回の代入が行われます。
例外
ExecutionPolicy
という名前のテンプレートパラメータを持つオーバーロードは、
以下のようにエラーを報告します:
-
アルゴリズムの一部として呼び出された関数の実行が例外をスローした場合、
ExecutionPolicyが 標準ポリシー のいずれかであるとき、 std::terminate が呼び出されます。それ以外のExecutionPolicyについては、動作は実装定義です。 - アルゴリズムがメモリの確保に失敗した場合、 std::bad_alloc がスローされます。
実装例
実装例については libstdc++ 、 libc++ 、および MSVC STL も参照してください。
`、`
`タグ内のテキストは翻訳せず、元のフォーマットを保持しました。C++固有の用語も翻訳していません。
例
#include <algorithm> #include <iostream> #include <iterator> #include <vector> int main() { std::vector<int> src{1, 2, 3, 4, 5}; std::vector<int> dest(src.size()); auto pivot = std::find(src.begin(), src.end(), 3); std::rotate_copy(src.begin(), pivot, src.end(), dest.begin()); for (int i : dest) std::cout << i << ' '; std::cout << '\n'; // 回転結果を直接 std::cout にコピー pivot = std::find(dest.begin(), dest.end(), 1); std::rotate_copy(dest.begin(), pivot, dest.end(), std::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; }
出力:
3 4 5 1 2 1 2 3 4 5
関連項目
|
範囲内の要素の順序を回転させる
(関数テンプレート) |
|
|
(C++20)
|
範囲の要素をコピーして回転させる
(アルゴリズム関数オブジェクト) |