std::accumulate用于累加容器元素,默认加法,需指定迭代器范围和初始值;支持自定义二元操作、浮点精度控制及C++20变换组合。
用 std::accumulate 累加容器中的数值非常直接,它属于 头文件,核心作用是将一个范围内的元素按二元操作(默认是加法)依次合并成单个值。
最常见场景是对 std::vector、std::array 等序列求和。需要传入起始迭代器、结束迭代器和初始值:
0.0 得到 double 结果)[first, last),即不包含 last 指向的元素示例:
std::vector第四个参数可传入任意二元函数对象(如 lambda、函数指针或仿函数),实现乘积、最大值、字符串拼接等:
T op(T a, U b),其中 a 是当前累加结果,b 是下一个元素示例(计算乘积):
int product = std::accumulate(v.begin(), v.end(), 1, std::multiplies{}); // 24
st std::string& b) { return a + "-" + b; });
对 float 或 double 累加时,初始值类型需明确,避免隐式转换导致中间截断:
0.0 而非 0 作为初始值,确保以浮点类型累加accumulate 按从左到右顺序执行,不保证数值稳定性;对高精度要求场景,可考虑 std::reduce(C++17,并行+乱序优化)或 Kahan 求和算法示例:
std::vectorstd::accumulate 可与 std::transform_iterator(需 和自定义包装)或 C++20 的 std::views::transform 配合,实现“先变换再累加”逻辑(注意:C++20 前需手动构造迭代器或先生成临时容器):
auto sq_sum = std::accumulate(data.begin(), data.end(), 0.0, [](double a, int b) { return a + b*b; });
std::transform 存入新容器,再 accumulate —— 适合逻辑复杂或需复用变换结果的场景