Namensräume
Varianten
Aktionen

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

Von cppreference.com
 
 
Bereichsbibliothek
Range-Adaptoren
 
 
constexpr iterator<false> begin()
    requires (!/*simple-view*/<First> || ... || !/*simple-view*/<Vs>);
(1) (seit C++23)
constexpr iterator<true> begin() const
    requires (ranges::range<const First> && ... && ranges::range<const Vs>);
(2) (seit C++23)

Gibt einen Iterator zum ersten Element der cartesian_product_view zurück.

Sei bases_ das Tupel der zugrunde liegenden Views.

1) Äquivalent zu return /*iterator*/<false>(tuple-transform(ranges::begin, bases_));.
2) Äquivalent zu return /*iterator*/<true>(tuple-transform(ranges::begin, bases_));.

Inhalt

[bearbeiten] Parameter

(keine)

[bearbeiten] Rückgabewert

Ein Iterator zum ersten Element.

[bearbeiten] Beispiel

#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');
}

Ausgabe

CRTP

[bearbeiten] Siehe auch

gibt einen Iterator oder Sentinel zum Ende zurück
(öffentliche Member-Funktion) [edit]
gibt einen Iterator zum Anfang eines Ranges zurück
(Customization Point Objekt)[edit]