std::rotate_copy - cppreference.com (original) (raw)

Defined in header
template< class ForwardIt, class OutputIt > OutputIt rotate_copy( ForwardIt first, ForwardIt middle, ForwardIt last, OutputIt d_first ); (1) (constexpr since C++20)
template< class ExecutionPolicy, class ForwardIt1, class ForwardIt2 >ForwardIt2 rotate_copy( ExecutionPolicy&& policy, ForwardIt1 first, ForwardIt1 middle, ForwardIt1 last, ForwardIt2 d_first ); (2) (since C++17)

Copies the left rotation of [first, last) to d_first.

  1. Copies the elements from the range [first, last), such that in the destination range beginning at d_first, the elements in [first, middle) are placed after the elements in [middle, last) while the orders of the elements in both ranges are preserved.

  2. Same as (1), but executed according to policy.

This overload participates in overload resolution only if all following conditions are satisfied:

If any of the following conditions is satisfied, the behavior is undefined:

Contents

[edit] Parameters

first, last - the pair of iterators defining the source range of elements to copy
middle - an iterator to an element in [first, last) that should appear at the beginning of the new range
d_first - beginning of the destination range
policy - the execution policy to use
Type requirements
-ForwardIt, ForwardIt1, ForwardIt2 must meet the requirements of LegacyForwardIterator.
-OutputIt must meet the requirements of LegacyOutputIterator.

[edit] Return value

Output iterator to the element past the last element copied.

[edit] Complexity

Exactly std::distance(first, last) assignments.

[edit] Exceptions

The overload with a template parameter named ExecutionPolicy reports errors as follows:

[edit] Possible implementation

See also the implementations in libstdc++, libc++, and MSVC STL.

template<class ForwardIt, class OutputIt> constexpr // since C++20 OutputIt rotate_copy(ForwardIt first, ForwardIt middle, ForwardIt last, OutputIt d_first) { d_first = std::copy(middle, last, d_first); return std::copy(first, middle, d_first); }

[edit] Example

#include #include #include #include   int main() { std::vector src{1, 2, 3, 4, 5}; std::vector 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';   // copy the rotation result directly to the std::cout pivot = std::find(dest.begin(), dest.end(), 1); std::rotate_copy(dest.begin(), pivot, dest.end(), std::ostream_iterator(std::cout, " ")); std::cout << '\n'; }

Output:

[edit] See also