C++ Numeric 库 - inner_product
描述
它用于计算范围的累积内积,并返回 init 与从 first1 和 first2 开始的两个范围的元素形成的对的内积的累加结果。
声明
以下是 std::inner_product 的声明。
C++98
template <class InputIterator1, class InputIterator2, class T> T inner_product (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, T init); template <class InputIterator1, class InputIterator2, class T, class BinaryOperation1, class BinaryOperation2> T inner_product (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, T init, BinaryOperation1 binary_op1, BinaryOperation2 binary_op2);
C++11
template <class InputIterator1, class InputIterator2, class T> T inner_product (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, T init); template <class InputIterator1, class InputIterator2, class T, class BinaryOperation1, class BinaryOperation2> T inner_product (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, T init, BinaryOperation1 binary_op1, BinaryOperation2 binary_op2);
first, last − 它迭代到序列中的初始位置和最终位置。
init − 它是累加器的初始值。
binary_op − 是二元运算。
binary_op2 − 它是二元运算并取两个元素。
返回值
它返回累加 init 的结果以及从 first1 和 first2 开始的范围内所有元素对的乘积。
异常
如果对元素或迭代器的任何操作抛出,它就会抛出。
数据竞争
访问 range [first1,last1) 中的元素。
示例
在下面的 std::adjacent_difference 示例中。
#include <iostream> #include <functional> #include <numeric> int myaccumulator (int x, int y) {return x-y;} int myproduct (int x, int y) {return x+y;} int main () { int init = 100; int series1[] = {20,30,40}; int series2[] = {1,2,3}; std::cout << "Default inner_product: "; std::cout << std::inner_product(series1,series1+3,series2,init); std::cout << '\n'; std::cout << "Functional operations: "; std::cout << std::inner_product(series1,series1+3,series2,init, std::minus<int>(),std::divides<int>()); std::cout << '\n'; std::cout << "Ccustom functions: "; std::cout << std::inner_product(series1,series1+3,series2,init, myaccumulator,myproduct); std::cout << '\n'; return 0; }
输出应该是这样的 −
Default inner_product: 300 Functional operations: 52 Ccustom functions: 4