Пространства имён
Варианты
Действия

std::inner_product

Материал из cppreference.com
< cpp‎ | algorithm

 
 
Алгоритмы
Функции
Немодифицирующие линейные операции
Модифицирующие линейные операции
Разделение
Сортировка (на отсортированных промежутках)
Бинарный поиск (на отсортированных промежутках)
Множества (на отсортированных промежутках)
Куча
Минимум/максимум
Числовые операции
iota(C++11)
accumulate
inner_product
Библиотека C
 
Определено в заголовочном файле <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 Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

Содержание

[править] Параметры

first1, last1 -
Первый диапазон элементов
Оригинал:
the first range of elements
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
first2 -
В начале второго ряда элементов
Оригинал:
the beginning of the second range of elements
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
value -
Начальное значение суммы произведений
Оригинал:
initial value of the sum of the products
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.
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 Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

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 Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

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 and CopyConstructible.

[править] Возвращаемое значение

Скалярное произведение двух диапазонах.
Оригинал:
The inner product of two ranges.
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

[править] Возможная реализация

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

[править] См. также

суммирует диапазон элементов
(шаблон функции) [edit]
вычисляет частичную сумму ряда элементов
Оригинал:
computes the partial sum of a range of elements
Текст был переведён автоматически через Google Translate.
Вы можете проверить и исправить перевод. Для инструкций кликните сюда.

(шаблон функции) [edit]