std::accumulate
|
|
This page has been machine-translated from the English version of the wiki using Google Translate.
The translation may contain errors and awkward wording. Hover over text to see the original version. You can help to fix errors and improve the translation. For instructions click here. |
| Заголовочный файл <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.
Содержание |
[править] Параметры
| first, last | - | диапазон элементов в сумме
Original: the range of elements to sum The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. | |||||||||
| init | - | initial value of the sum | |||||||||
| op | - | применяемый функциональный объект, задающий бинарную операцию. Сигнатура функции должна быть эквивалента следующей:
В сигнатуре не обязательно наличие const &. | |||||||||
| Требования, накладываемые на типы | |||||||||||
-InputIt должен соответствовать требованиям InputIterator.
| |||||||||||
-T должен соответствовать требованиям CopyAssignable и CopyConstructible.
| |||||||||||
[править] Возвращаемое значение
The sum of the given value and elements in the given range.
[править] Возможная реализация
| Первый вариант |
|---|
template<class InputIt, class T> T accumulate(InputIt first, InputIt last, T value) { for (; first != last; ++first) { value = value + *first; } return value; } |
| Второй вариант |
template<class InputIt, class T, class BinaryOperation> T accumulate(InputIt first, InputIt last, T value, BinaryOperation op) { for (; first != last; ++first) { value = op(value, *first); } return value; } |
[править] Пример
#include <iostream> #include <vector> #include <numeric> #include <string> int multiply(int x, int y) { return x*y; } std::string magic_function(std::string res, int x) { return res += (x > 5) ? "b" : "s"; } int main() { std::vector<int> v{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; int sum = std::accumulate(v.begin(), v.end(), 0); int product = std::accumulate(v.begin(), v.end(), 1, multiply); std::string magic = std::accumulate(v.begin(), v.end(), std::string(), magic_function); std::cout << sum << '\n' << product << '\n' << magic << '\n'; }
Вывод:
55 3628800 sssssbbbbb
[править] См. также
| вычисляет скалярное произведение двух диапазонах элементы Original: computes the inner product of two ranges of elements The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (шаблон функции) | |
| вычисляет частичную сумму ряда элементов Original: computes the partial sum of a range of elements The text has been machine-translated via Google Translate. You can help to correct and verify the translation. Click here for instructions. (шаблон функции) | |