std::accumulate
Defined in header <numeric>
|
||
template< class InputIt, class T > T accumulate( InputIt first, InputIt last, T init ); |
(1) | |
template< class InputIt, class T, class BinaryOperation > T accumulate( InputIt first, InputIt last, T init, |
(2) | |
Computes the sum of the given value init
and the elements in the range [first, last)
. The first version uses operator+
to sum up the elements, the second version uses the given binary function op
.
|
(until C++11) |
|
(since C++11) |
Parameters
first, last | - | the range of elements to sum |
init | - | initial value of the sum |
op | - | binary operation function object that will be applied. The binary operator takes the current accumulation value a (initialized to init ) and the value of the current element b . The signature of the function should be equivalent to the following: Ret fun(const Type1 &a, const Type2 &b); The signature does not need to have const &. |
Type requirements | ||
-InputIt must meet the requirements of InputIterator .
| ||
-T must meet the requirements of CopyAssignable and CopyConstructible .
|
Return value
Notes
Although std::accumulate
performs left fold by default, right fold may be achieved by using reverse iterators, e.g. std::accumulate(v.rbegin(), v.rend(), init, binop)
Possible implementation
First version |
---|
template<class InputIt, class T> T accumulate(InputIt first, InputIt last, T init) { for (; first != last; ++first) { init = init + *first; } return init; } |
Second version |
template<class InputIt, class T, class BinaryOperation> T accumulate(InputIt first, InputIt last, T init, BinaryOperation op) { for (; first != last; ++first) { init = op(init, *first); } return init; } |