partial_sum (STL Samples)
在 Visual C++ 演示如何使用 partial_sum 标准 (STL)模板库函数。
template<class InputIterator, class OutputIterator> inline
OutputIterator partial_sum(
InputIterator First,
InputIterator Last,
OutputIterator First2
)
template<
class InputIterator,
class OutputIterator,
class BinaryOperator
> inline
OutputIterator partial_sum(
InputIterator First,
InputIterator Last,
OutputIterator First2,
BinaryOperator Binary_Op
)
备注
备注
类/参数名在原型不匹配版本在头文件。修改某些提高可读性。
分配给每个迭代 我 该范围的 [因此,结果 (+Last -First)相应地值等于 (… (*First + * (First + 1)) +…)+ * (First + (i -结果))- 或 - Binary_Op(Binary_Op(…, Binary_Op(*First, * (First + 1),…), * (First + (i -结果))。 换言之, * (+ )结果 i= init + * (第 + 0) + * (第 + 1) +… + * (第 i +)。
示例
// partial_sum.cpp
// compile with: /EHsc
// Demonstrates the use of partial_sum().
//
// Description of partial_sum(first,last,first2,init)
// partial_sum(first,last,first2,init,binary_op):
//
// Assigns to every iterator i in the range
// [result,result + (last - first)) a value correspondingly equal to
// ((...(*first + *(first + 1)) + ...) + *(first + (i - result)))
//
// - or -
//
// binary_op(binary_op(..., binary_op(*first, *(first + 1)),...),
// *(first + (i - result)))
//
// In other words,
// *(result+i) = init + *(first+0) + *(first+1) + ... + *(first+i)
///////////////////////////////////////////////////////////////////////
#include <iostream>
#include <numeric>
#include <functional>
#include <vector>
#include <iterator>
using namespace std;
typedef vector < int > IntArray;
typedef ostream_iterator < int, char, char_traits<char> > IntOstreamIt;
int main ()
{
IntOstreamIt itOstream(cout," ");
// Initialize the array
IntArray rgI;
for (int i=1; i<=10; i++)
rgI.push_back(i);
// Print the arrays
cout << "Array: [ ";
copy(rgI.begin(),rgI.end(),itOstream);
cout << "]" << endl;
// The result array must be at least the same size as the data array
IntArray rgIresult(rgI.size());
// Compute the partial sum of the array
partial_sum(rgI.begin(),rgI.end(),rgIresult.begin());
// Print the array of partial sums
cout << "Array of partial sums: [ ";
copy(rgIresult.begin(),rgIresult.end(),itOstream);
cout << "]" << endl;
// Compute the partial product of the array
partial_sum(rgI.begin(),rgI.end(),rgIresult.begin(),multiplies<int>());
// Print the array of partial products
cout << "Array of partial products: [ ";
partial_sum(rgIresult.begin(),rgIresult.end(),itOstream);
cout << "]" << endl;
}
Output
Array: [ 1 2 3 4 5 6 7 8 9 10 ]
Array of partial sums: [ 1 3 6 10 15 21 28 36 45 55 ]
Array of partial products: [ 1 3 9 33 153 873 5913 46233 409113 4037913 ]
要求
**标题:**numeric