アフィリエイト広告を利用しています

広告

posted by fanblog

2018年02月26日

《その309》 sort関数(1)


 sort関数 による昇順ソート

 sort は、<algorithm>ヘッダが提供する、並べ替えを行うアルゴリズムです。

  template <class RandomAccessIterator>
  void sort(RandomAccessIterator first, RandomAccessIterator last);

 sort関数がソートすることができるのは、vector などのランダムアクセス反復子が使えるコンテナです。
また、ポインタはランダムアクセス反復子としての要件を満たしているため、sort関数は通常の配列をソートすることもできます。

 ベクトルの要素をソートするのに、前回《308》は、マージソート関数を作成し、それを使いました。
今回のプログラムでは sort関数を用いています。


#include <random>
#include <vector>
#include <iostream>
using namespace std;

template<class InputIterator>
void disp(InputIterator first, InputIterator last) {
for (InputIterator i = first; i != last; i++)
cout << ' ' << *i;
}

int main() {
random_device rd;
vector<int> x;

cout << "◆ベクトルのシャッフルとソート\n";
for (unsigned i = 0; i < 10; i++)
x.push_back(i);

cout << "シャッフル前\n";
disp(x.begin(), x.end()); cout << "\n\n";

cout << "シャッフル後\n";
shuffle(x.begin(), x.end(), rd);
disp(x.begin(), x.end()); cout << "\n\n";

cout << "ソート後\n";
sort(x.begin(), x.end()); // 昇順ソート
disp(x.begin(), x.end()); cout << "\n\n";

cout << "◆通常の配列のシャッフルとソート\n";
char c[] = {
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'
};

cout << "シャッフル前\n";
disp(c, c + 8); cout << "\n\n";

cout << "シャッフル後\n";
shuffle(c, c + 8, rd);
disp(c, c + 8); cout << "\n\n";

cout << "ソート後\n";
sort(c, c + 8);
disp(c, c + 8); cout << '\n';
}

g10_0057.png



この記事へのコメント
コメントを書く

お名前:

メールアドレス:


ホームページアドレス:

コメント:

※ブログオーナーが承認したコメントのみ表示されます。

この記事へのトラックバックURL
https://fanblogs.jp/tb/7364611
※ブログオーナーが承認したトラックバックのみ表示されます。

この記事へのトラックバック

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


検索
<< 2018年08月 >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
プロフィール
こうすけさんの画像
こうすけ

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


×

この広告は30日以上新しい記事の更新がないブログに表示されております。