◐ Shell
clean mode source ↗

std::inner_product — cppreference.com

Материал из cppreference.com

<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 для решения этих задач соответственно.

Оригинал:

Computes inner product (i.e. sum of products) of the range [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.

Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Параметры

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:

Ret fun(const Type1 &a, const Type2 &b);

The signature does not need to have const &.
Типы Type1 и Type2 должны быть таковы, что объекты типов T и Type3 могут быть неявно преобразованы в Type1 и Type2 соответственно. Тип Ret должен быть таков, что объекту типа T можно присвоить значение типа Ret. ​

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:

Ret fun(const Type1 &a, const Type2 &b);

The signature does not need to have const &.
Типы Type1 и Type2 должны быть таковы, что объекты типов InputIt1 и InputIt2 могут быть разыменованы и затем неявно преобразованы в Type1 и Type2 соответственно. Тип Ret должен быть таков, что объекту типа Type3 можно присвоить значение типа Ret. ​

Требования к типам
-InputIt1, InputIt2 должен соответствовать требованиям InputIterator.
-T должен соответствовать требованиям CopyAssignable и CopyConstructible.

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

Скалярное произведение двух диапазонах.

Оригинал:

The inner product of two ranges.

Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Возможная реализация

Первый вариант
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

См. также