adjacent_difference()是位于numeric头文件中,用来比较序列中相邻元素的差值,并将它们的差值保存到另外一个序列上。
因为第一个的前一个值为空,所以第一个元素会原封不动的复制到序列中,然后第二个元素和第一个元素相减结果作为新的第二个序列元素,再用第三个元素减去第二个元素得到新的第三个序列元素。由此类推。
它有两种写法,一种是上述的默认减法,另外一种就是定义运算法。如下:
减法:
自定义运算法:
代码如下:
#include <iterator>//ostream_iterator的使用
#include <numeric>//adjacent_difference的使用
#include<vector>
#include<iostream>
using namespace std;
void main() {
vector<int> data{ 2,3,1,5,2,8,4,2 };
cout << "相减:";
adjacent_difference(data.begin(), data.end(), ostream_iterator<int>(cout, " "));
cout << endl;
cout << "相加";
adjacent_difference(data.begin(), data.end(), ostream_iterator<int>(cout, " "), plus<int>());//加法
cout << endl;
cout << "相乘";
adjacent_difference(data.begin(), data.end(), ostream_iterator<int>(cout, " "), multiplies<int>());//乘法
}
结果如下: