std::ranges::cartesian_product_view<First, Vs...>::size
Von cppreference.com
< cpp | ranges | cartesian product view
| 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 /* vorzeichenloser Ganzzahl-ähnlicher */ Typ U.
Sei bases_ das zugrunde liegende 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.
Äquivalent zu
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)>{});
Inhalt |
[bearbeiten] Parameter
(keine)
[bearbeiten] Rückgabewert
Die Anzahl der Elemente, d.h. das Produkt der Größen aller zugrunde liegenden Bereiche.
[bearbeiten] Hinweise
Der Rückgabetyp ist der kleinste /* vorzeichenloser Ganzzahl-ähnlicher */ Typ, der breit genug ist, um das Produkt der maximalen Größen aller zugrunde liegenden Bereiche zu speichern, falls ein solcher Typ existiert.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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); }
[bearbeiten] Siehe auch
| (C++20) |
gibt eine Ganzzahl zurück, die der Größe eines Ranges entspricht (Customization Point Objekt) |
| (C++20) |
gibt eine vorzeichenbehaftete Ganzzahl zurück, die der Größe eines Ranges entspricht (Customization Point Objekt) |