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

📄 page115.cpp

📁 包含常见的数据结构的类和函数
💻 CPP
字号:
#include <iostream.h>#include <assert.h>template <class Type> class Queue{  public:    Queue(int=10);    ~Queue(){ delete []elements;}    void EnQueue(const Type & item);    Type DeQueue();    Type GetFront();    void MakeEmpty(){ front=rear=0;}    int  IsEmpty() const { return front==rear;}    int  IsFull() const { return (rear+1)%maxsize==front;}    int  Length() const { return (rear-front+maxsize)%maxsize;}  private:    int rear,front;    Type* elements;    int  maxsize;  }    template <class Type> Queue<Type>::Queue(int sz):front(0),rear(0),maxsize(sz){    elements=new Type[maxsize];    assert(elements!=0);    }  template <class Type> void Queue<Type>::EnQueue(const Type & item){    assert(!IsFull());    rear=(rear+1)%maxsize;    elements[rear]=item;    }  template <class Type> Type Queue<Type>::DeQueue(){    assert(!IsEmpty());    front=(front+1)%maxsize;    return elements[front];    }  template <class Type> Type Queue<Type>::GetFront(){    assert(!IsEmpty());    return elements[(front+1)%maxsize];    }void main(){  Queue<int> que(7);  for(int i;!que.IsFull();i++)que.EnQueue(i);  cout<<que.Length()<<que.GetFront();  for(;!que.IsEmpty();)cout<<que.DeQueue();  }

⌨️ 快捷键说明

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