std::inner_product
|
|
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google. Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Щёлкните здесь, чтобы увидеть английскую версию этой страницы. (Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке.) |
<metanoindex/>
<tbody> </tbody>| Определено в заголовочном файле <numeric>
|
||
template< class InputIt1, class InputIt2, class T > T inner_product( InputIt1 first1, InputIt1 last1, InputIt2 first2, T value ); |
(1) | |
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 ); |
(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 | — | Первый диапазон элементов
Оригинал: the first range of elements Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
| first2 | — | В начале второго ряда элементов
Оригинал: the beginning of the second range of elements Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
| value | — | Начальное значение суммы произведений
Оригинал: initial value of the sum of the products Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
| op1 | — | binary operation function object that will be applied. Эта функция принимает значение, возвращенное op2 и текущее значение аккумулятора и производит новое значение сохраняется в аккумуляторе . Оригинал: This function takes a value returned by op2 and the current value of the accumulator and produces a new value to be stored in the accumulator. Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. The signature of the function should be equivalent to the following:
The signature does not need to have |
| op2 | — | binary operation function object that will be applied. Эта функция принимает одно значение из каждого диапазона и создает новое значение . Оригинал: This function takes one value from each range and produces a new value. Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. The signature of the function should be equivalent to the following:
The signature does not need to have |
| Требования к типам | ||
-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
См. также
| суммирует или сворачивает ряд элементов (шаблон функции) | |
| вычисляет частичную сумму диапазона элементов (шаблон функции) |