Cpp-standard-library-cpp-adjacent-difference
提供:Dev Guides
C ++数値ライブラリ-隣接差分
説明
隣接する範囲の差を計算します。
宣言
- 以下は、std
- adjacent_differenceの宣言です。
C 98
template <class InputIterator, class OutputIterator>
OutputIterator adjacent_difference (InputIterator first, InputIterator last,
OutputIterator result);
template <class InputIterator, class OutputIterator, class BinaryOperation>
OutputIterator adjacent_difference ( InputIterator first, InputIterator last,
OutputIterator result, BinaryOperation binary_op );
C 11
template <class InputIterator, class OutputIterator>
OutputIterator adjacent_difference (InputIterator first, InputIterator last,
OutputIterator result);
template <class InputIterator, class OutputIterator, class BinaryOperation>
OutputIterator adjacent_difference ( InputIterator first, InputIterator last,
OutputIterator result, BinaryOperation binary_op );
- first、last -シーケンスの最初と最後の位置を反復します。
- init -アキュムレータの初期値です。
- binary_op -バイナリ操作です。
戻り値
結果の要素が格納されている宛先シーケンスの最後の要素を指すイテレータを返します。
例外
binary_op、割り当て、またはイテレータの操作のいずれかがスローされた場合にスローされます。
データの競合
範囲[first1、last1)の要素にアクセスします。
例
- 以下のstd
- adjacent_differenceの例。
#include <iostream>
#include <functional>
#include <numeric>
int myop (int x, int y) {return x+y;}
int main () {
int val[] = {10,20,30,50,60,70};
int result[7];
std::adjacent_difference (val, val+7, result);
std::cout << "Default adjacent_difference: ";
for (int i=0; i<7; i++) std::cout << result[i] << ' ';
std::cout << '\n';
std::adjacent_difference (val, val+7, result, std::multiplies<int>());
std::cout << "Functional operation multiplies: ";
for (int i=0; i<7; i++) std::cout << result[i] << ' ';
std::cout << '\n';
std::adjacent_difference (val, val+7, result, myop);
std::cout << "Custom function operation: ";
for (int i=0; i<7; i++) std::cout << result[i] << ' ';
std::cout << '\n';
return 0;
}
出力は次のようになります-
Default adjacent_difference: 10 10 10 20 10 10 4197079
Functional operation multiplies: 10 200 600 1500 3000 4200 293800430
Custom function operation: 10 30 50 80 110 130 4197219