std::ranges:: reverse
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::
bidirectional_iterator
I,
std::
sentinel_for
<
I
>
S
>
requires
std::
permutable
<
I
>
|
(1) | (depuis C++20) |
|
template
<
ranges::
bidirectional_range
R
>
requires
std::
permutable
<
ranges::
iterator_t
<
R
>>
|
(2) | (depuis C++20) |
[
first
,
last
)
.
i
, où
0
≤ i
<
(
last
-
first
)
/
2
.
Les entités de type fonction décrites sur cette page sont des objets fonction d'algorithme (informellement appelés niebloids ), c'est-à-dire :
- Les listes d'arguments de template explicites ne peuvent pas être spécifiées lors de l'appel de l'une d'entre elles.
- Aucune d'entre elles n'est visible pour la recherche dépendante des arguments .
- Lorsque l'une d'entre elles est trouvée par la recherche non qualifiée normale comme nom à gauche de l'opérateur d'appel de fonction, la recherche dépendante des arguments est inhibée.
Table des matières |
Paramètres
| first, last | - | la paire itérateur-sentinelle définissant la plage des éléments à inverser |
| r | - | la plage d'éléments à inverser |
Valeur de retour
Un itérateur égal à last .
Complexité
Exactement ( last - first ) / 2 échanges.
Notes
Les implémentations (par exemple
MSVC STL
) peuvent activer la vectorisation lorsque le type d'itérateur modélise
contiguous_iterator
et que l'échange de son type de valeur n'appelle ni fonction membre spéciale non triviale ni
ADL
-trouvée
swap
.
Implémentation possible
Voir aussi les implémentations dans libstdc++ et MSVC STL .
struct reverse_fn { template<std::bidirectional_iterator I, std::sentinel_for<I> S> requires std::permutable<I> constexpr I operator()(I first, S last) const { auto last2 {ranges::next(first, last)}; for (auto tail {last2}; !(first == tail or first == --tail); ++first) ranges::iter_swap(first, tail); return last2; } template<ranges::bidirectional_range R> requires std::permutable<ranges::iterator_t<R>> constexpr ranges::borrowed_iterator_t<R> operator()(R&& r) const { return (*this)(ranges::begin(r), ranges::end(r)); } }; inline constexpr reverse_fn reverse {}; |
` n'a pas été traduit - Les termes spécifiques au C++ sont conservés en anglais - Le formatage original est maintenu
Exemple
#include <algorithm> #include <array> #include <iostream> #include <string> int main() { std::string s {"ABCDEF"}; std::cout << s << " → "; std::ranges::reverse(s.begin(), s.end()); std::cout << s << " → "; std::ranges::reverse(s); std::cout << s << " │ "; std::array a {1, 2, 3, 4, 5}; for (auto e : a) std::cout << e << ' '; std::cout << "→ "; std::ranges::reverse(a); for (auto e : a) std::cout << e << ' '; std::cout << '\n'; }
Sortie :
ABCDEF → FEDCBA → ABCDEF │ 1 2 3 4 5 → 5 4 3 2 1
Voir aussi
|
(C++20)
|
crée une copie d'une plage qui est inversée
(objet fonction algorithme) |
une
view
qui itère sur les éléments d'une autre vue bidirectionnelle en ordre inverse
(modèle de classe) (objet adaptateur de plage) |
|
|
inverse l'ordre des éléments dans une plage
(modèle de fonction) |