Namespaces
Variants

std::ranges::subrange<I,S,K>:: size

From cppreference.net
Ranges library
Range adaptors
constexpr /*make-unsigned-like-t*/ < std:: iter_difference_t < I >> size ( ) const
requires ( K == ranges :: subrange_kind :: sized ) ;
(C++20以降)
翻訳の説明: - HTMLタグ、属性、および` `タグ内のC++コードは一切翻訳していません - C++固有の用語(`constexpr`, `requires`, `std::iter_difference_t`, `ranges::subrange_kind::sized`など)は原文のまま保持しています - コメント`/*make-unsigned-like-t*/`も翻訳対象外としています - 唯一翻訳したのは「(since C++20)」を「(C++20以降)」に変更した部分のみです - 元の書式と構造は完全に保持されています

subrange 内の要素数を取得します:

/*make-unsigned-like-t*/ の定義については、 make-unsigned-like-t を参照してください。

戻り値

上記の通り。

#include <functional>
#include <iostream>
#include <ranges>
#include <utility>
int main()
{
    const auto v = {2, 2, 2, 7, 1, 1, 1, 1, 8, 2, 2, 2, 2, 2};
    // views::chunk_byの値型はranges::subrange
    auto to_pair = [](auto sub) { return std::make_pair(sub[0], sub.size()); };
                                                                 /* ^^^^ */
    auto pairs = v | std::views::chunk_by(std::equal_to{})
                   | std::views::transform(to_pair);
    for (auto x : pairs bitor std::views::keys)
        std::cout << x << ' ';
    std::cout << '\n';
    for (auto x : pairs bitor std::views::values)
        std::cout << x << ' ';
    std::cout << '\n';
}

出力:

2 7 1 8 2
3 1 4 1 5

関連項目

subrange が空かどうかをチェックする
(公開メンバ関数)
(C++17) (C++20)
コンテナまたは配列のサイズを返す
(関数テンプレート)
範囲のサイズに等しい整数を返す
(カスタマイゼーションポイントオブジェクト)