inner_product

inner_product

來源:inner_product是c++標準庫封裝。
函式原型:inner_product(beg1, end1, beg2, init)
inner_product(beg1, end1, beg2, init, BinOp1, BinOp2)
函式介紹:
返回作為兩個序列乘積而生成的元素的總和。步調一致地檢查兩個序列,將
來自兩個序列的元素相乘,將相乘的結果求和。由 init 指定和的初值。假定從
beg2 開始的第二個序列具有至少與第一個序列一樣多的元素,忽略第二個序列
中超出第一個序列長度的任何元素。init 的類型決定返回類型。
第一個版本使用元素的乘操作符(*)和加操作符(+):給定兩個序列 2,3,5,8
和 1,2,3,4,5,6,7,結果是初值加上下面的乘積對:
initial_value + (2 * 1) + (3 * 2) + (5 * 3) + (8 * 4)
如果提供初值 0,則結果是 55。
第二個版本套用指定的二元操作,使用第一個操作代替加而第二個操作代替
乘。作為例子,可以使用 inner_product 來產生以括弧括住的元素的名-值對
的列表,這裡從第一個輸入序列獲得名字,從第二個序列中獲得對應的值:
// combine elements into a parenthesized, comma-separated pair
string combine(string x, string y)
{
return "(" + x + ", " + y + ")";
}
// add two strings, each separated by a comma
string concatenate(string x, string y)
{
if (x.empty())
return y;
return x + ", " + y;
}
cout << inner_product(names.begin(), names.end(),
values.begin(), string(),
concatenate, combine);
如果第一個序列包含 if、
string 和 sort,
且第二個序列包含 keyword、
library
type 和 algorithm,則輸出將是
(if, keyword), (string, library type), (sort, algorithm)

相關詞條

熱門詞條

聯絡我們