Namespaces
Variants

std::deque<T,Allocator>:: rend, std::deque<T,Allocator>:: crend

From cppreference.net

reverse_iterator rend ( ) ;
(1) (noexcept depuis C++11)
(constexpr depuis C++26)
const_reverse_iterator rend ( ) const ;
(2) (noexcept depuis C++11)
(constexpr depuis C++26)
const_reverse_iterator crend ( ) const noexcept ;
(3) (depuis C++11)
(constexpr depuis C++26)

Renvoie un itérateur inverse au-delà du dernier élément de la version inversée de * this . Il correspond à l'élément précédant le premier élément de la version non inversée de * this .

Cet itérateur retourné agit uniquement comme un sentinelle. Il n'est pas garanti qu'il soit déréférençable .

range-rbegin-rend.svg

Table des matières

Valeur de retour

Itérateur inverse vers l'élément suivant le dernier élément.

Complexité

Constante.

Notes

libc++ rétroporte crend() au mode C++98.

Exemple

#include <algorithm>
#include <iostream>
#include <numeric>
#include <string>
#include <deque>
int main()
{
    std::deque<int> nums{1, 2, 4, 8, 16};
    std::deque<std::string> fruits{"orange", "apple", "raspberry"};
    std::deque<char> empty;
    // Afficher la deque.
    std::for_each(nums.rbegin(), nums.rend(), [](const int n) { std::cout << n << ' '; });
    std::cout << '\n';
    // Additionne tous les entiers dans la deque nums (s'il y en a), affichant uniquement le résultat.
    std::cout << "Somme de nums : "
              << std::accumulate(nums.rbegin(), nums.rend(), 0) << '\n';
    // Affiche le premier fruit dans la deque fruits, en vérifiant s'il y en a.
    if (!fruits.empty())
        std::cout << "Premier fruit : " << *fruits.rbegin() << '\n';
    if (empty.rbegin() == empty.rend())
        std::cout << "La deque 'empty' est effectivement vide.\n";
}

Sortie :

16 8 4 2 1
Sum of nums: 31
First fruit: raspberry
deque 'empty' is indeed empty.

Voir aussi

retourne un itérateur inverse vers le début
(fonction membre publique)
(C++14)
retourne un itérateur inverse de fin pour un conteneur ou un tableau
(fonction template)