问题及代码:
/*
*Copyright(c)2016,烟台大学计算机与控制工程学院
*All right reserved.
*文件名称:77.cpp
*作 者:董凯琦
*完成日期:2016年6月7日
*版 本 号:v1.0
*
*问题描述:
阅读程序,体会STL用法
*输入描述:
*程序输出:
*/
#include <algorithm>
#include <functional>
#include <vector>
#include <iostream>
#include <numeric>
#include <iterator>
using namespace std;
int main()
{
int a[] = {1,4,7,2,5,8};
int b[] = {1,2,3,3,2,1};
const int ASZ = sizeof a / sizeof a[0];
const int BSZ = sizeof b / sizeof b[0];
ostream_iterator<int> out(cout," ");
copy(a, a + ASZ, out);
cout<<endl;
copy(b, b + BSZ, out);
cout<<endl;
int r = accumulate(a, a + ASZ, 0);
cout << "accumulate 1: " << r << endl;
// Should produce the same result:
r = accumulate(b, b + BSZ, 0, plus<int>());
cout << "accumulate 2: " << r << endl;
r = inner_product(a, a + ASZ, b, 0);
// 或 r = inner_product(a, a + ASZ, b, 0, plus<int>(), multiplies<int>());
cout << "inner_product : " << r << endl;
int* it = partial_sum(a, a + ASZ, b);
// 或 int* it = partial_sum(a, a + ASZ, b, plus<int>());
copy(b, it, out);
cout<<endl;
it = adjacent_difference(a, a + ASZ, b);
// 或 it = adjacent_difference(a, a + ASZ, b, minus<int>());
copy(b, it, out);
cout<<endl;
return 0;
}
运行结果:
程序分析:
1、sizeof a表示数组a的字节数,sizeof a[0]表示a[0]的字节数,故sizeof a/size of a[0]表示数组a里元素的个数
2、构建输出迭代器out,将数组a,数组b里的元素依次输出
3、求和,并输出结果
4、inner_product:返回作为两个序列乘积而生成的元素的总和。步调一致地检查两个序列,将
来自两个序列的元素相乘,将相乘的结果求和。由 init 指定和的初值。