std::ranges::cartesian_product_view<First, Vs...>::size
From cppreference.com
< cpp | ranges | cartesian product view
| constexpr /* 説明を参照 */ size() requires /*cartesian-product-is-sized*/<First, Vs...>; |
(1) | (C++23から) |
| constexpr /* 説明を参照 */ size() const requires /*cartesian-product-is-sized*/<const First, const Vs...>; |
(2) | (C++23から) |
要素数を返します。戻り値の型は、実装定義の /* unsigned-integer-like */ 型 U です。
基になるビューのタプルを bases_ とし、bases_ 内のすべての範囲のサイズの積を prod とします。
1,2) prod を返します。prod が戻り値の型 U で表現できない場合、動作は未定義です。
以下と等価です。
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)>{});
目次 |
[編集] パラメータ
(なし)
[編集] 戻り値
要素数、つまり、すべての基になる範囲のサイズの積。
[編集] 注記
戻り値の型は、すべての基になる範囲の最大サイズの積を格納するのに十分な幅を持つ、最小の /* unsigned-integer-like */ 型です。ただし、そのような型が存在する場合に限ります。
[編集] 例
このコードを実行
#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); }
[編集] 関連項目
| (C++20) |
rangeのサイズと等しい整数を返す (カスタマイゼーションポイントオブジェクト) |
| (C++20) |
rangeのサイズと等しい符号付き整数を返す (カスタマイゼーションポイントオブジェクト) |