Namespaces
Variants

operator- (ranges::zip_view:: sentinel )

From cppreference.net
Ranges library
Range adaptors
template < bool OtherConst >

requires ( std:: sized_sentinel_for <
ranges:: sentinel_t < /*maybe-const*/ < Const, Views >> ,
ranges:: iterator_t < /*maybe-const*/ < OtherConst, Views >>> && ... )
friend constexpr
std:: common_type_t < ranges:: range_difference_t < /*maybe-const*/ < OtherConst, Views >> ... >

operator - ( const iterator < OtherConst > & x, const sentinel & y ) ;
(1) (desde C++23)
template < bool OtherConst >

requires ( std:: sized_sentinel_for <
ranges:: sentinel_t < /*maybe-const*/ < Const, Views >> ,
ranges:: iterator_t < /*maybe-const*/ < OtherConst, Views >>> && ... )
friend constexpr
std:: common_type_t < ranges:: range_difference_t < /*maybe-const*/ < OtherConst, Views >> ... >

operator - ( const sentinel & y, const iterator < OtherConst > & x ) ;
(2) (desde C++23)

Calcula la distancia mínima entre la tupla subyacente de iteradores de x y la tupla subyacente de centinelas de y .

Estas funciones no son visibles para la búsqueda no calificada o calificada ordinaria, y solo pueden ser encontradas mediante búsqueda dependiente de argumentos cuando zip_view:: sentinel <Const> es una clase asociada de los argumentos.

Parámetros

x - un iterator
y - un sentinel

Valor de retorno

Sea current_ la tupla subyacente de iteradores de x , y end_ la tupla subyacente de centinelas de y .

Sea DIST (x, y, i) una distancia calculada por una expresión equivalente a std :: get < i > ( x. current_ ) - std :: get < i > ( y. end_ ) para algún entero i .

1) el valor con el valor absoluto más pequeño entre DIST (x, y, i) de todos los i en el rango 0 ≤ i < sizeof...(Views)
2) - ( x - y ) .

Ejemplo

#include <cassert>
#include <deque>
#include <list>
#include <ranges>
#include <vector>
int main()
{
    auto x = std::vector{1, 2, 3, 4};
    auto y = std::deque{'a', 'b', 'c'};
    auto z = {1.1, 2.2};
    auto w = std::list{1, 2, 3};
    auto p = std::views::zip(x, y, z);
    assert(p.begin() - p.end() == +2);
    assert(p.end() - p.begin() == -2);
    [[maybe_unused]]
    auto q = std::views::zip(x, y, w);
    // El siguiente código genera un error en tiempo de compilación porque std::list::iterator
    // no soporta el operador- que se necesita para calcular la distancia:
    // auto e = q.begin() - q.end();
}