Namespaces
Variants

std::ranges::subrange<I,S,K>:: prev

From cppreference.net
Ranges library
Range adaptors
constexpr subrange prev ( std:: iter_difference_t < I > n = 1 ) const
requires std:: bidirectional_iterator < I > ;
(depuis C++20)

Retourne une copie de * this dont le begin_ est décrémenté (ou incrémenté si n est négatif). L'opération de décrémentation (ou d'incrémentation) réelle est effectuée par advance() .

Équivalent à : auto tmp = * this ;
tmp. advance ( - n ) ;
return tmp ;
.

Table des matières

Paramètres

n - nombre de décrémentations de l'itérateur

Valeur de retour

Comme décrit ci-dessus.

Notes

La différence entre cette fonction et advance() est que cette dernière effectue la décrémentation (ou l'incrémentation) en place.

Exemple

#include <iterator>
#include <list>
#include <print>
#include <ranges>
int main()
{
    std::list list{1, 2, 3, 4, 5};
    std::ranges::subrange sub{std::next(list.begin(), 2), std::prev(list.end(), 2)};
    std::println("{} {} {}", sub, sub.prev(), sub.prev(2));
}

Sortie :

[3] [2, 3] [1, 2, 3]

Voir aussi

obtient une copie du subrange avec son itérateur avancé d'une distance donnée
(fonction membre publique)
avance l'itérateur d'une distance donnée
(fonction membre publique)
(C++11)
décrémente un itérateur
(fonction template)
décrémente un itérateur d'une distance donnée ou jusqu'à une limite
(objet fonction algorithme)