Namespaces
Variants

std::ranges:: rotate_copy, std::ranges:: rotate_copy_result

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
(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
Constrained algorithms
All names in this menu belong to namespace std::ranges
Non-modifying sequence operations
Modifying sequence operations
Partitioning operations
Sorting operations
Binary search operations (on sorted ranges)
Set operations (on sorted ranges)
Heap operations
Minimum/maximum operations
Permutation operations
Fold operations
Operations on uninitialized storage
Return types
Défini dans l'en-tête <algorithm>
Signature d'appel
template < std:: forward_iterator I, std:: sentinel_for < I > S,

std:: weakly_incrementable O >
requires std:: indirectly_copyable < I, O >
constexpr rotate_copy_result < I, O >

rotate_copy ( I first, I middle, S last, O result ) ;
(1) (depuis C++20)
template < ranges:: forward_range R, std:: weakly_incrementable O >

requires std:: indirectly_copyable < ranges:: iterator_t < R > , O >
constexpr rotate_copy_result < ranges:: borrowed_iterator_t < R > , O >

rotate_copy ( R && r, ranges:: iterator_t < R > middle, O result ) ;
(2) (depuis C++20)
Types auxiliaires
template < class I, class O >
using rotate_copy_result = in_out_result < I, O > ;
(3) (depuis C++20)

Copie la rotation gauche de [ first , last ) vers result .

1) Copie les éléments de la plage source [ first , last ) , de sorte que dans la plage de destination, les éléments de [ first , middle ) soient placés après les éléments de [ middle , last ) , tout en préservant l'ordre des éléments dans les deux plages.
Le comportement est indéfini si l'un ou l'autre des intervalles [ first , middle ) ou [ middle , last ) n'est pas un intervalle valide, ou si les intervalles source et destination se chevauchent.
2) Identique à (1) , mais utilise r comme plage source, comme si on utilisait ranges:: begin ( r ) comme first et ranges:: end ( r ) comme last .

Les entités de type fonction décrites sur cette page sont des objets fonction d'algorithme (informellement appelés niebloids ), c'est-à-dire :

Table des matières

Paramètres

first, last - la paire itérateur-sentinelle définissant la plage source des éléments à copier
r - la plage source des éléments à copier
middle - l'itérateur vers l'élément qui doit apparaître au début de la plage de destination
result - début de la plage de destination

Valeur de retour

{ last, result + N } , où N = ranges:: distance ( first, last ) .

Complexité

Linéaire : exactement N affectations.

Notes

Si le type de valeur est TriviallyCopyable et que les types d'itérateurs satisfont contiguous_iterator , les implémentations de ranges::rotate_copy évitent généralement les assignations multiples en utilisant une fonction de "copie en bloc" telle que std::memmove .

Implémentation possible

Voir également les implémentations dans libstdc++ et MSVC STL .

struct rotate_copy_fn
{
    template<std::forward_iterator I, std::sentinel_for<I> S, std::weakly_incrementable O>
    requires std::indirectly_copyable<I, O>
    constexpr ranges::rotate_copy_result<I, O>
        operator()(I first, I middle, S last, O result) const
    {
        auto c1 {ranges::copy(middle, std::move(last), std::move(result))};
        auto c2 {ranges::copy(std::move(first), std::move(middle), std::move(c1.out))};
        return {std::move(c1.in), std::move(c2.out)};
    }
    template<ranges::forward_range R, std::weakly_incrementable O>
    requires std::indirectly_copyable<ranges::iterator_t<R>, O>
    constexpr ranges::rotate_copy_result<ranges::borrowed_iterator_t<R>, O>
        operator()(R&& r, ranges::iterator_t<R> middle, O result) const
    {
        return (*this)(ranges::begin(r), std::move(middle),
                       ranges::end(r), std::move(result));
    }
};
inline constexpr rotate_copy_fn rotate_copy {};

Exemple

#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::ranges::find(src, 3);
    std::ranges::rotate_copy(src, pivot, dest.begin());
    for (int i : dest)
        std::cout << i << ' ';
    std::cout << '\n';
    // copier directement le résultat de la rotation vers std::cout
    pivot = std::ranges::find(dest, 1);
    std::ranges::rotate_copy(dest, pivot, std::ostream_iterator<int>(std::cout, " "));
    std::cout << '\n';
}

Sortie :

3 4 5 1 2
1 2 3 4 5

Voir aussi

fait pivoter l'ordre des éléments dans une plage
(objet fonction algorithme)
copie une plage d'éléments vers un nouvel emplacement
(objet fonction algorithme)
copie et fait pivoter une plage d'éléments
(modèle de fonction)