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

広告

posted by fanblog

2018年02月06日

《その278》 抽象クラステンプレート利用のキュー( vector<>で実現 )


 今回も、抽象クラステンプレート Queue<> を利用する形式のキューを作成します。
今回は配列や線形リストではなく、vector<>クラステンプレートを用いてキューを実現します。
※ vector<>クラステンプレートは、《275》でも使いました。
今回のプログラムも、このあとの演習問題で必要になります。

 今回のプログラムでは、vector<>の次の機能を使っています。
  ・push_back関数による、末尾へ要素追加
  ・empty関数による、空かどうかの判定
  ・front関数による先頭要素の取得
  ・erase(que.begin())による、que の先頭要素の削除


 以下がプログラムです。

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

// ------------------------------------

// 抽象クラステンプレート Queue<>

template <class Type> class Queue {
public:
class Overflow { }; // Overflow例外
class Empty { }; // Empty例外

// 純粋仮想デストラクタ
virtual ~Queue() = 0;

// 純粋仮想関数 push
virtual void enqueue(const Type&) = 0;

// 純粋仮想関数 pop
virtual Type dequeue() = 0;
};

template <class Type>
Queue<Type>::~Queue() { }


// ------------------------------------

// テンプレートライブラリ vector<>
// によるキュー VectorQueue<>

template <class Type> class VectorQueue
: public Queue<Type> {

// データメンバとしての
// べクトルオブジェクト que の宣言

vector<Type> que;

public:
// コンストラクタ
VectorQueue() { }

// デストラクタ
~VectorQueue() { }

// enque
void enqueue(const Type& x) {
try {
// 末尾へ要素追加(push_back関数)
que.push_back(x);
}
catch (...) {
throw Queue<Type>::Overflow();
}
}

// dequeue
Type dequeue() {
// 要素が空かどうかの判定(empty関数)
if (que.empty())
throw Queue<Type>::Empty();

// 先頭要素を取得(front関数)
Type x = que.front();

// 先頭要素の削除
que.erase(que.begin());
return x;
}
};

// ------------------------------------

// クラステンプレートの利用プログラム
int main() {
VectorQueue<int> q;

while (1) {
int f; int n;
cout << "◆ 1.enqueue 2.dequeue "
"0.終了 : ";
cin >> f;

if (f == 1) {
try {
cout << " 整数 : "; cin >> n;
q.enqueue(n);
}
catch (Queue<int>::Overflow&) {
cout << " Overflow!\n";
}
}
else if (f == 2) {
try {
cout << " " << q.dequeue()
<< '\n';
}
catch (Queue<int>::Empty&) {
cout << " Empty!\n";
}
}
else
break;
}
}

f09_0090.png

f09_0091.png



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

お名前:

メールアドレス:


ホームページアドレス:

コメント:

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

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

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

 たまに、クリック お願いします 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日以上新しい記事の更新がないブログに表示されております。