Namespaces
Variants

std:: copy_backward

From cppreference.net
Algorithm library
Constrained algorithms and algorithms on ranges (C++20)
Constrained algorithms, e.g. ranges::copy , ranges::sort , ...
Execution policies (C++17)
Non-modifying sequence operations
Batch operations
(C++17)
Search operations
Modifying sequence operations
Copy operations
copy_backward
(C++11)
(C++11)
Swap operations
Transformation operations
Generation operations
Removing operations
Order-changing operations
(until C++17) (C++11)
(C++20) (C++20)
Sampling operations
(C++17)

Sorting and related operations
Partitioning operations
Sorting operations
Binary search operations
(on partitioned ranges)
Set operations (on sorted ranges)
Merge operations (on sorted ranges)
Heap operations
Minimum/maximum operations
Lexicographical comparison operations
Permutation operations
C library
Numeric operations
Operations on uninitialized memory
Определено в заголовке <algorithm>
template < class BidirIt1, class BidirIt2 >
BidirIt2 copy_backward ( BidirIt1 first, BidirIt1 last, BidirIt2 d_last ) ;
(constexpr начиная с C++20)

Копирует элементы из диапазона [ first , last ) в другой диапазон, заканчивающийся на d_last . Элементы копируются в обратном порядке (последний элемент копируется первым), но их относительный порядок сохраняется.

Поведение не определено, если d_last находится в диапазоне ( first , last ] . В этом случае необходимо использовать std::copy вместо std::copy_backward .

Содержание

Параметры

first, last - пара итераторов, определяющих исходный диапазон элементов для копирования
d_last - конец целевого диапазона
Требования к типам
-
BidirIt должен удовлетворять требованиям LegacyBidirectionalIterator .

Возвращаемое значение

Итератор на последний скопированный элемент.

Сложность

Ровно std:: distance ( first, last ) присваиваний.

Примечания

При копировании перекрывающихся диапазонов, std::copy следует использовать при копировании влево (начало целевого диапазона находится вне исходного диапазона), тогда как std::copy_backward следует использовать при копировании вправо (конец целевого диапазона находится вне исходного диапазона).

Возможная реализация

template<class BidirIt1, class BidirIt2>
BidirIt2 copy_backward(BidirIt1 first, BidirIt1 last, BidirIt2 d_last)
{
    while (first != last)
        *(--d_last) = *(--last);
    return d_last;
}

Пример

#include <algorithm>
#include <iostream>
#include <numeric>
#include <vector>
int main()
{
    std::vector<int> source(4);
    std::iota(source.begin(), source.end(), 1); // заполняет значениями 1, 2, 3, 4
    std::vector<int> destination(6);
    std::copy_backward(source.begin(), source.end(), destination.end());
    std::cout << "destination содержит: ";
    for (auto i: destination)
        std::cout << i << ' ';
    std::cout << '\n';
}

Вывод:

destination contains: 0 0 1 2 3 4

Отчеты о дефектах

Следующие отчеты об изменениях в поведении, содержащие описания дефектов, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Applied to Behavior as published Correct behavior
LWG 1206 C++98 1. the behavior was well-defined if d_last == last
2. the behavior was undefined if d_last == first
1. made undefined
2. made well-defined

Смотрите также

копирует диапазон элементов в новое местоположение
(шаблон функции)
копирует диапазон элементов в обратном порядке
(функциональный объект алгоритма)