Namespaces
Variants

std::ranges::cartesian_product_view<First, Vs...>:: size

From cppreference.net
Ranges library
Range adaptors
constexpr /* siehe Beschreibung */ size ( )
requires /*cartesian-product-is-sized*/ < First, Vs... > ;
(1) (seit C++23)
constexpr /* siehe Beschreibung */ size ( ) const
requires /*cartesian-product-is-sized*/ < const First, const Vs... > ;
(2) (seit C++23)

Gibt die Anzahl der Elemente zurück. Der Rückgabetyp ist ein implementierungsdefinierter /*unsigned-integer-like*/ Typ U .

Sei bases_ das zugrundeliegende Tupel von Views, und prod das Produkt der Größen aller Bereiche in bases_ .

1,2) Gibt prod zurück. Das Verhalten ist undefiniert, wenn prod nicht durch den Rückgabetyp U dargestellt werden kann.

Entspricht:

return [&]<std::size_t... Is>(std::index_sequence<Is...>)
{
    auto prod = static_cast<U>(1);
    prod = (static_cast<U>(ranges::size(std::get<Is>(bases_))) * ...);
    return prod;
}
(std::make_index_sequence<1U + sizeof...(Vs)>{});

Inhaltsverzeichnis

Parameter

(keine)

Rückgabewert

Die Anzahl der Elemente, also das Produkt der Größen aller zugrundeliegenden Bereiche.

Hinweise

Der Rückgabetyp ist der kleinste /*unsigned-integer-like*/ Typ, der breit genug ist, um das Produkt der maximalen Größen aller zugrundeliegenden Bereiche zu speichern, falls ein solcher Typ existiert.

Beispiel

#include <ranges>
int main()
{
    constexpr static auto w = {1};
    constexpr static auto x = {2, 3};
    constexpr static auto y = {4, 5, 6};
    constexpr static auto z = {7, 8, 9, 10, 11, 12, 13};
    constexpr auto v = std::ranges::cartesian_product_view(w, x, y, z);
    static_assert(v.size() == w.size() * x.size() * y.size() * z.size() and v.size() == 42);
}

Siehe auch

gibt einen ganzzahligen Wert zurück, der der Größe eines Ranges entspricht
(Anpassungspunktobjekt)
gibt einen vorzeichenbehafteten ganzzahligen Wert zurück, der der Größe eines Ranges entspricht
(Anpassungspunktobjekt)