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부터)

cartesian_product_view 의 첫 번째 요소에 대한 iterator 를 반환합니다.

bases_ 를 기본 뷰들의 튜플이라고 하자.

1) 다음에 해당함 return /*iterator*/ < false > ( tuple-transform ( ranges:: begin , bases_ ) ) ; .
2) 다음과 동일함 return /*iterator*/ < true > ( tuple-transform ( ranges:: begin , bases_ ) ) ; .

목차

매개변수

(없음)

반환값

첫 번째 요소를 가리키는 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

참고 항목

끝을 가리키는 반복자나 센티널을 반환합니다
(public member function)
범위의 시작을 가리키는 반복자를 반환합니다
(customization point object)