📄 queue.h
字号:
#include <iostream.h>
template<class T>
class Queue
{
public:
Queue(int MaxQueueSize=10);
~Queue(){delete [] queue;}
bool IsEmpty() {return front==rear;}
bool IsFull()
{
if((rear+1)%MaxSize==front)
return 1;
else
return 0;
}
T First();//返回队首元素
T Last() ;//返回队尾元素
void enqueue(const T& x);
void dequeue(T& x);
private:
int front; //与第一个元素在反时针方向上相差一个位置
int rear; //指向最后一个元素
int MaxSize;//队列数组的大小
T *queue; //数组
};
template<class T>
Queue<T>::Queue(int MaxQueueSize)
{
MaxSize=MaxQueueSize;
queue=new T[MaxSize];
front=rear=0;
}
template<class T>
T Queue<T>::First()
{
if(IsEmpty())
return -1;
else
return queue[(front+1)%MaxSize];
}
template<class T>
T Queue<T>::Last()
{
if(IsEmpty())
return -1;
else
return queue[rear];
}
template<class T>
void Queue<T>::enqueue(const T& x)
{
if(IsFull())
{ cout<<"no memeory";return; }
rear=(rear+1)%MaxSize;
queue[rear]=x;
return;
}
template<class T>
void Queue<T>::dequeue(T& x)
{
if(IsEmpty())
{ cout<<"no element";return; }
front=(front+1)%MaxSize;
x=queue[front];
return;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -