最終更新日時(UTC):
が更新

履歴 編集

function
<ranges>

std::ranges::chunk_view::size(C++23)

constexpr auto size() requires sized_range<V>;             // (1) C++23

constexpr auto size() const requires sized_range<const V>; // (2) C++23

概要

要素数(チャンク数)を取得する。

効果

以下と等価:

return to-unsigned-like(div-ceil(ranges::distance(base_), n_));

ここで、to-unsigned-likeは説明専用の関数であり、整数型を対応する符号なし整数型に変換する。div-ceil(x, y)xyで割った切り上げを計算する説明専用の関数である。

備考

元のRangeの要素数をnで割った切り上げがチャンク数となる。

#include <ranges>
#include <vector>
#include <iostream>

int main() {
  std::vector<int> v = {1, 2, 3, 4, 5, 6, 7, 8};

  // 3要素ずつのチャンクに分割
  std::ranges::chunk_view cv1{v, 3};
  std::cout << "chunk_view(8 elements, chunk size 3): " << cv1.size() << " chunks" << std::endl;

  // 5要素ずつのチャンクに分割
  std::ranges::chunk_view cv2{v, 5};
  std::cout << "chunk_view(8 elements, chunk size 5): " << cv2.size() << " chunks" << std::endl;
}

出力

chunk_view(8 elements, chunk size 3): 3 chunks
chunk_view(8 elements, chunk size 5): 2 chunks

バージョン

言語

  • C++23

処理系

参照