⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pr1303.cpp

📁 practice c++, it is from the book http://www.amazon.com/Schaums-Outline-Programming-John-Hubbard
💻 CPP
字号:
//  Programming with C++, Second Edition, by John R. Hubbard
//  Copyright McGraw-Hill 2000
//  Problem 13.3, page 319
//  Queue Template

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

template<class T>
class Queue
{
public:
  Queue(int s = 100) : size(s+1), front(0), rear(0)
  {
    data = new T[size]; 
  }
  ~Queue() { delete [] data; }
  void insert(const T& x) { data[rear++ % size] = x; }
  T  remove() { return data[front++ % size]; }
  int isEmpty() const { return front == rear; }
  int isFull() const { return ((rear+1) % size == front); }
private:
  int size, front, rear;
  T* data;
};

int main()
{
  Queue<char> q(3);
  q.insert('A');
  q.insert('B');
  q.insert('C');
  if (q.isFull()) cout << "Queue is full.\n";
  else cout << "Queue is not full.\n";
  cout << q.remove() << endl;
  cout << q.remove() << endl;
  q.insert('D');
  q.insert('E');
  if (q.isFull()) cout << "Queue is full.\n";
  else cout << "Queue is not full.\n";
  cout << q.remove() << endl;
  cout << q.remove() << endl;
  cout << q.remove() << endl;
  if (q.isFull()) cout << "Queue is full.\n";
  else cout << "Queue is not full.\n";
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -