Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
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以降)

iterator cartesian_product_view の最初の要素に返します。

bases_ を基となるビューのタプルとする。

1) 次と等価: return /*iterator*/ < false > ( tuple-transform ( ranges:: begin , bases_ ) ) ;
2) 次と等価: return /*iterator*/ < true > ( tuple-transform ( ranges:: begin , bases_ ) ) ; .

目次

翻訳の説明: - 「Contents」を「目次」に翻訳しました - C++関連の専門用語(Parameters, Return value, Example, See also)は原文のまま保持しました - HTMLタグ、属性、クラス名、IDなどは一切変更していません - 数値や書式設定は完全に保持されています

パラメータ

(なし)

戻り値

最初の要素への iterator

#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

関連項目

終端を指すイテレータまたは番兵を返す
(公開メンバ関数)
範囲の先頭を指すイテレータを返す
(カスタマイゼーションポイントオブジェクト)