贝利信息

c++ accumulate函数_c++数组求和与累加

日期:2026-01-08 00:00 / 作者:裘德小鎮的故事
std::accumulate是C++中基于迭代器的通用累加函数,适用于vector、原生数组等任意满足输入迭代器要求的范围;正确用法为accumulate(arr, arr + n, 0),初值不可随意省略以防类型不匹配或空范围未定义行为。

accumulate 是什么,用在哪儿

std::accumulate 是 C++ 标准库 头文件里提供的通用累加函数,不是专为数组设计的,而是作用于任意满足输入迭代器要求的范围(比如 std::vector、原生数组、std::array,甚至 std::list)。它不关心容器类型,只依赖起始和结束迭代器。

常见误用是以为它“只能对 vector 求和”,其实对原生数组一样有效,只要传入指针即可——因为指针本身就是随机访问迭代器。

对原生 C 风格数组用 accumulate 的正确写法

原生数组没有 .begin() / .end() 成员函数,必须手动计算边界。最容易出错的是传错右边界:它应指向「末尾元素的下一个位置」,不是末尾元素本身。

int arr[] = {10, 20, 30};
int sum = std::accumulate(arr, arr + std::size(arr), 0); // 结果 60

第三个参数(初值)为什么不能随便省略

std::accumulate 有两版重载:带初值和不带初值。不带初值版本(只有两个迭代器参数)要求容器元素类型支持 operator+,且返回类型与元素类型一致。但一旦初值类型不同,就必须显式提供——否则编译失败或隐式转换引发意外。

立即学习“C++免费学习笔记(深入)”;

手写 for 循环快吗?有什么代价

在优化开启(-O2)的前提下,std::accumulate 和朴素 for 循环生成的汇编几乎一致,现代编译器能完全内联并展开。它没有运行时性能损失,但有两个隐含成本:

真正容易被忽略的是:它不做任何越界检查,也不验证迭代器有效性。传入野指针或 arr + n + 1,行为未定义——这和裸指针操作一样危险。