Skip to content

Latest commit

 

History

History
76 lines (58 loc) · 2.03 KB

ranges_generate_n.md

File metadata and controls

76 lines (58 loc) · 2.03 KB

generate_n

  • algorithm[meta header]
  • std::ranges[meta namespace]
  • function template[meta id-type]
  • cpp20[meta cpp]
namespace std::ranges {
  template <input_or_output_iterator O,
            copy_constructible F>
    requires invocable<F&> && indirectly_writable<O, invoke_result_t<F&>>
  constexpr O
    generate_n(O first,
               iter_difference_t<O> n,
               F gen);                  // (1) C++20
}
  • input_or_output_iterator[link /reference/iterator/input_or_output_iterator.md]
  • copy_constructible[link /reference/concepts/copy_constructible.md]
  • invocable[link /reference/concepts/invocable.md]
  • indirectly_writable[link /reference/iterator/indirectly_writable.md]
  • invoke_result_t[link /reference/type_traits/invoke_result.md]

概要

出力の範囲へ関数の結果を n 個書き込む。

効果

n が 1 以上の場合、[first,last) のそれぞれのイテレータについて関数オブジェクト gen を呼び出し、その戻り値を代入する。

そうでない場合、何もしない。

戻り値

n が 1 以上の場合、first + n が返される。
そうでない場合、first が返される。

計算量

n が 1 以上の場合、n 回の gen の呼び出しと代入が行われる。

そうでない場合、何もしない。

#include <algorithm>
#include <iostream>
#include <iterator>

int main() {
  // 2 の累乗の値を生成して出力する
  int n = 1;
  std::ranges::generate_n(std::ostream_iterator<int>(std::cout, ","), 10, [&n]{ auto t = n; n *= 2; return t; });
}
  • std::ranges::generate_n[color ff0000]

出力

1,2,4,8,16,32,64,128,256,512,

バージョン

言語

  • C++20

処理系

参照