Поделиться через


accumulate

Вычисляет сумму всех элементов в заданном диапазоне, включая некоторые начальное значение путем группирования последовательные частично суммы или вычисляет результат последовательных частично результатов аналогично полученных от использования определенной бинарной операции, отличный от суммы.

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 
   );

Параметры

  • _First
    Итератор ввода слишком первый элемент в диапазоне, добавляется или объединяется с указанной бинарной операцией.

  • _Last
    Итератор ввода слишком последний элемент в диапазоне, добавляется или объединяется с указанной бинарной операцией, одна положение за окончательным элементом, включенные в повторенном накоплении.

  • _Val
    Начальное значение для каждого элемента, который в свою очередь, добавляется или объединяется с указанной бинарной операцией.

  • _Binary_op
    Бинарная операция, которая, применяются к каждому элементу в указанном диапазоне и его результатов предыдущих приложений.

Возвращаемое значение

Количество _Val и всех элементов в указанном диапазоне для первой функции шаблона, или для второй шаблонной функции, результат применения бинарная операция, вместо операции суммы, в (PartialResult, *Iter), где PartialResult является результатом описанной приложений операции и Iter — итератор, указывающий на элемент в диапазоне.

Заметки

Начальное значение гарантирует, что результат будет четкий при диапазон является пустым, в случае, _Val возвращается. Бинарной операции не должны быть ассоциативна или коммутативна. Результат инициализируется к начальному значению _Val и затем результат = _Binary_op (результат, *****Iter) вычисляются итеративно через диапазон, где Iter итератор, указывающего на работающий подряд элемент в диапазоне. Диапазон должен быть допустимым и сложность линейная с размером диапазона. Возвращаемый тип бинарного оператора должен быть преобразуемым к Тип для закрытия во время итерации.

Пример

// 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;
}
  

Требования

Заголовок:<numeric>

Пространство имен: std

См. также

Ссылки

accumulate, copy и vector::push_back

Библиотека стандартных шаблонов