2018年03月01日
《その313》transformアルゴリズム(2)
transformアルゴリズム
template <class InputIterator, class OutputIterator, class UnaryOperation>
OutputIterator transform(InputIterator first, InputIterator last,
OutputIterator result, UnaryOperation op);
template <class InputIterator1, class InputIterator2,
class OutputIterator, class BinaryOperation>
OutputIterator transform(InputIterator1 first1,
InputIterator1 last1,
InputIterator2 first2,
OutputIterator result,
BinaryOperation binary_op);
前回《312》では、上記の 2番目の形式の transform を使いました。
今回は、1番目の形式の transform を使ったプログラムです。
下記のプログラムでは、最初に、
vector<char> a0;
を作成し、小文字の 'a'〜'z' を順番に格納します。
次に、
vector<char> a1(a0.size());
として a0 と同じサイズの a1 を用意します。
ファンクタ f は、アルファベットの小文字を受け取って、それを大文字に変換して返却します。
transform は、コンテナ a0 の要素を、f を使って変換し、その結果をコンテナ a1 に格納します。
transform(
a0.begin(), a0.end(), a1.begin(), f()
);
以下は、プログラムです。
#include <vector>
#include <algorithm>
#include <iostream>
using namespace std;
struct f
: public unary_function<const char, char>
{
char operator()(const char c) {
int d = 'A' - 'a';
return c + d;
}
};
int main()
{
vector<char> a0;
for (char i = 'a'; i <= 'z'; i++)
a0.push_back(i);
vector<char> a1(a0.size());
transform(
a0.begin(), a0.end(), a1.begin(), f()
);
for (
vector<char>::size_type i = 0;
i < a0.size();
i++
)
cout << a0[i];
cout << '\n';
for (
vector<char>::size_type i = 0;
i < a1.size();
i++
)
cout << a1[i];
cout << '\n';
}
この記事へのコメント
コメントを書く
この記事へのトラックバックURL
https://fanblogs.jp/tb/7377335
※ブログオーナーが承認したトラックバックのみ表示されます。
この記事へのトラックバック