std::inner_product
|
|
该页由英文版wiki使用Google Translate机器翻译而来。
该翻译可能存在错误或用词不当。鼠标停留在文本上可以看到原版本。你可以帮助我们修正错误或改进翻译。参见说明请点击这里. |
| 定义于头文件 <numeric>
|
||
| template< class InputIt1, class InputIt2, class T > T inner_product( InputIt1 first1, InputIt1 last1, |
(1) | |
| template< class InputIt1, |
(2) | |
[first1, last1)和其他范围内开始在first2。第一个版本使用operator*计算元素对产品和operator+总结的产品,第二个版本使用op2和op1这些任务.[first1, last1) and another range beginning at first2. The first version uses operator* to compute product of the element pairs and operator+ to sum up the products, the second version uses op2 and op1 for these tasks respectively.目录 |
[编辑] 参数
| first1, last1 | - | |
| first2 | - | |
| value | - | |
| op1 | - | 被使用的二元函数对象。 此函数需要一个返回值op2的累加器的当前值,并产生一个新的值被存储在累加器中. 该函数的签名应当等价于: Ret fun(const Type1 &a, const Type2 &b); 签名中并不需要有 const &。 |
| op2 | - | 被使用的二元函数对象。 这个函数接受一个值从每个范围,并产生一个新的价值. 该函数的签名应当等价于: Ret fun(const Type1 &a, const Type2 &b); 签名中并不需要有 const &。 |
| 类型要求 | ||
-InputIt1, InputIt2 必须满足 InputIterator 的要求。
| ||
-T 必须满足 CopyAssignable 和 CopyConstructible 的要求。
| ||
[编辑] 返回值
[编辑] 可能的实现
| 版本一 |
|---|
template<class InputIt1, class InputIt2, class T> T inner_product(InputIt1 first1, InputIt1 last1, InputIt2 first2, T value) { while (first1 != last1) { value = value + *first1 * *first2; ++first1; ++first2; } return value; } |
| 版本二 |
template<class InputIt1, class InputIt2, class T, class BinaryOperation1, class BinaryOperation2> T inner_product(InputIt1 first1, InputIt1 last1, InputIt2 first2, T value, BinaryOperation1 op1 BinaryOperation2 op2) { while (first1 != last1) { value = op1(value, op2(*first1, *first2)); ++first1; ++first2; } return value; } |
[编辑] 示例
#include <numeric> #include <iostream> #include <vector> #include <functional> int main() { std::vector<int> a{0, 1, 2, 3, 4}; std::vector<int> b{5, 4, 2, 3, 1}; int r1 = std::inner_product(a.begin(), a.end(), b.begin(), 0); std::cout << "Inner product of a and b: " << r1 << '\n'; int r2 = std::inner_product(a.begin(), a.end(), b.begin(), 0, std::plus<int>(), std::equal_to<int>()); std::cout << "Number of pairwise matches between a and b: " << r2 << '\n'; }
输出:
Inner product of a and b: 21 Number of pairwise matches between a and b: 2
[编辑] 另请参阅
| 计算区间内元素的和 (函数模板) | |
| 计算区间内元素的部分和 (函数模板) |