确定 C 向量中元素的总和
在 C 中,求 std::vector 中元素的总和需要一个循环或标准算法来迭代并累积值。方法的选择取决于所使用的 C 版本,每种方法都有自己的优点。
C 03
经典for 循环: 使用传统的 for 循环迭代元素并递增运行总和
int sum_of_elems = 0; for (auto it = vector.begin(); it != vector.end(); ++it) sum_of_elems += *it;
累积算法:此算法由
#include <numeric> int sum_of_elems = std::accumulate(vector.begin(), vector.end(), 0);
C 11 及更高版本
std::accumulate with auto-typing: 相同std::accumulate 算法稍加修改即可根据向量的元素类型自动推断返回类型。
#include <numeric> decltype(vector)::value_type sum_of_elems = std::accumulate(vector.begin(), vector.end(), decltype(vector)::value_type(0));
std::for_each 循环: 此循环语法将 lambda 函数应用于向量的每个元素,更新其内的 sum 变量range.
std::for_each(vector.begin(), vector.end(), [&](int n) { sum_of_elems += n; });
基于范围的 for 循环: 这种 for 循环语法糖直接迭代元素,无需单独的迭代器对象。
for (auto& n : vector) sum_of_elems += n;
C 17 和稍后
std::reduce 算法: 该算法使用特定的二元运算符将集合的元素组合成单个结果,在本例中为加法。它还会自动推断结果类型。
#include <numeric> auto result = std::reduce(v.begin(), v.end());
以上是如何有效地对 C 向量的元素求和?的详细内容。更多信息请关注PHP中文网其他相关文章!