accumulate
Oblicza sumę wszystkich elementów w określonym zakresie tym niektóre wartości początkowej przez obliczenie sumy w kolejnych kolumnach lub oblicza wynik kolejne wyniki częściowe podobnie uzyskanej przy użyciu określonej operacji binarny innych niż suma.
template<class InputIterator, class Type>
Type accumulate(
InputIterator _First,
InputIterator _Last,
Type _Val
);
template<class InputIterator, class Type, class BinaryOperation>
Type accumulate(
InputIterator _First,
InputIterator _Last,
Type _Val,
BinaryOperation _Binary_op
);
Parametry
_First
Wejściowy iteratora adresowania pierwszy element w zakresie mają być sumowane lub Scalonej według określonej operacji binarny._Last
Wejściowy iteratora adresowania ostatniego elementu w zakresie mają być sumowane lub Scalonej według określonej operacji binarny, który jest poza ostatni element faktycznie włączone w gromadzeniu się iterowany o jedną pozycję._Val
Początkowa wartość, do której każdy element jest z kolei dodane lub w połączeniu z według określonej operacji binarny._Binary_op
Operacji binarny, który ma być stosowany do każdego elementu w określonym zakresie i wynik jego wcześniejszych wniosków.
Wartość zwracana
Suma _Val i wszystkie elementy w określonym zakresie Pierwsza funkcja szablonu lub, dla drugiej funkcji szablonu, w wyniku zastosowania określonej zamiast operacji Suma do operacji binarny (PartialResult, * Iter), gdzie PartialResult wynika z wcześniejszych wniosków operacji i Iter jest iterację wskazując polecenie element w zakresie.
Uwagi
Wartość początkowa gwarantuje, że będzie dobrze zdefiniowanych wynik gdy zakres jest pusta, w którym to przypadku _Val jest zwracany.Operacji binarnych nie musi być zespolone lub Przemienne.Wynik jest ustawiana na wartość początkowa _Val a wynik = _Binary_op (wynik, *****Iter) jest obliczana iteracyjnie poprzez zakres, gdzie Iter jest iterację wskazując polecenie Następny element w zakresie.Zakres musi być prawidłowy i złożoność jest liniowy z rozmiar zakresu.Zwracany typ operatora binarnego musi być konwertowany na typu zapewnienie zamknięcia podczas iteracji.
Przykład
// numeric_accum.cpp
// compile with: /EHsc
#include <vector>
#include <numeric>
#include <functional>
#include <iostream>
int main( )
{
using namespace std;
vector <int> v1, v2(20);
vector <int>::iterator iter1, iter2;
int i;
for (i = 1; i < 21; i++)
{
v1.push_back(i);
}
cout << "The original vector v1 is:\n ( " ;
for (iter1 = v1.begin(); iter1 != v1.end(); iter1++)
cout << *iter1 << " ";
cout << ")." << endl;
// The first member function for the accumulated sum
int total;
total = accumulate(v1.begin(), v1.end(), 0);
cout << "The sum of the integers from 1 to 20 is: "
<< total << "." << endl;
// Constructing a vector of partial sums
int j = 0, partotal;
for (iter1 = v1.begin(); iter1 != v1.end(); iter1++)
{
partotal = accumulate(v1.begin(), iter1 + 1, 0);
v2[j] = partotal;
j++;
}
cout << "The vector of partial sums is:\n ( " ;
for (iter2 = v2.begin(); iter2 != v2.end(); iter2++)
cout << *iter2 << " ";
cout << ")." << endl << endl;
// The second member function for the accumulated product
vector <int> v3, v4(10);
vector <int>::iterator iter3, iter4;
int s;
for (s = 1; s < 11; s++)
{
v3.push_back(s);
}
cout << "The original vector v3 is:\n ( " ;
for (iter3 = v3.begin(); iter3 != v3.end(); iter3++)
cout << *iter3 << " ";
cout << ")." << endl;
int ptotal;
ptotal = accumulate(v3.begin(), v3.end(), 1, multiplies<int>());
cout << "The product of the integers from 1 to 10 is: "
<< ptotal << "." << endl;
// Constructing a vector of partial products
int k = 0, ppartotal;
for (iter3 = v3.begin(); iter3 != v3.end(); iter3++) {
ppartotal = accumulate(v3.begin(), iter3 + 1, 1, multiplies<int>());
v4[k] = ppartotal;
k++;
}
cout << "The vector of partial products is:\n ( " ;
for (iter4 = v4.begin(); iter4 != v4.end(); iter4++)
cout << *iter4 << " ";
cout << ")." << endl;
}
Wymagania
Nagłówek:<numeryczne>
Przestrzeń nazw: std