对 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中文网其他相关文章!