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

std::inner_product

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

 
 
Библиотека алгоритмов
Ограниченные алгоритмы и алгоритмы над диапазонами(C++20)
Ограниченные алгоритмы, например ranges::copy, ranges::sort, ...
Политики исполнения (C++17)
Немодифицирующие операции над последовательностями
(C++11)(C++11)(C++11)
(C++17)
Модифицирующие операции над последовательностями
Операции разбиения
Операции сортировки
Операции двоичного поиска
Операции с наборами (в отсортированных диапазонах)
Операции с кучей
(C++11)
Операций минимума/максимума
(C++11)
(C++17)

Операции перестановки
Числовые операции
(C++11)
inner_product
Операции с неинициализированной памятью
(C++17)
(C++17)
(C++17)
Библиотека 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.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Содержание

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

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

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

суммирует или сворачивает ряд элементов
(шаблон функции)[править]
вычисляет частичную сумму диапазона элементов
(шаблон функции)[править]
close