std::rotate_copy - cppreference.com (original) (raw)
Copies the left rotation of [
first,
last)
to d_first.
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.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:
[
first,
middle)
or[
middle,
last)
is not a valid range.- The source and destination ranges overlap.
Contents
- 1 Parameters
- 2 Return value
- 3 Complexity
- 4 Exceptions
- 5 Possible implementation
- 6 Example
- 7 See also
[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:
- If execution of a function invoked as part of the algorithm throws an exception and
ExecutionPolicy
is one of the standard policies, std::terminate is called. For any otherExecutionPolicy
, the behavior is implementation-defined. - If the algorithm fails to allocate memory, std::bad_alloc is thrown.
[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: