std::vector 内の要素を合計する効率的な方法
std 内の要素の累積合計を確認する必要があるシナリオ::vector には、いくつかの効率的なアプローチが存在します。
C 03 ソリューション:
クラシック For ループ:
int sum_of_elems = 0; for (std::vector<int>::iterator it = vector.begin(); it != vector.end(); ++it) sum_of_elems += *it;
標準アルゴリズム:
#include <numeric> sum_of_elems = std::accumulate(vector.begin(), vector.end(), 0);
注: 最後の引数の型によって、初期値と結果の型が決まります。浮動小数点入力の場合は、0 の代わりに 0.0 を使用します。
C 11 以降の拡張機能:
自動ベクトルタイプ処理:
#include <numeric> sum_of_elems = std::accumulate(vector.begin(), vector.end(), decltype(vector)::value_type(0));
std::for_each 利用:
std::for_each(vector.begin(), vector.end(), [&](int n) { sum_of_elems += n; });
範囲ベースの対象ループ:
for (auto& n : vector) sum_of_elems += n;
C 17 以降の追加:
std::自動結果による削減型:
#include <numeric> auto result = std::reduce(v.begin(), v.end());
この関数のオーバーロードにより、大規模なコレクションの並列処理が可能になります。
以上がC で std::vector の要素を合計する効率的な方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。