std::ranges::cartesian_product_view<First, Vs...>::begin
From cppreference.com
< cpp | ranges | cartesian product view
| constexpr iterator<false> begin() requires (!/*simple-view*/<First> || ... || !/*simple-view*/<Vs>); |
(1) | (C++23から) |
| constexpr iterator<true> begin() const requires (ranges::range<const First> && ... && ranges::range<const Vs>); |
(2) | (C++23から) |
cartesian_product_view の最初の要素へのイテレータを返します。
基底となるビューのタプルを bases_ とします。
1)
tuple-transform(ranges::begin, bases_)); と同等です。2)
tuple-transform(ranges::begin, bases_)); と同等です。目次 |
[編集] パラメータ
(なし)
[編集] 戻り値
最初の要素へのイテレータ。
[編集] 例
このコードを実行
#include <array> #include <format> #include <iostream> #include <ranges> #include <string_view> #include <tuple> using namespace std::literals; int main() { constexpr auto a = std::array{"Curiously"sv, "Recurring"sv, "Template"sv, "Pattern"sv}; constexpr auto v = std::ranges::cartesian_product_view(a[0], a[1], a[2], a[3]); constexpr std::tuple<char const&, char const&, char const&, char const&> first{*v.begin()}; std::cout << std::format("{}{}{}{}{}", std::get<0>(first), std::get<1>(first), std::get<2>(first), std::get<3>(first), '\n'); }
出力
CRTP
[編集] 関連項目
| 終端へのイテレータまたはセンチネルを返す (public メンバ関数) | |
| (C++20) |
rangeの先頭を指すイテレータを返す (カスタマイゼーションポイントオブジェクト) |