#include<iostream> using namespace std;
const int maxqueue = 10;
class Queue
{
public: Queue( );
bool empty( ) const;
Error_code serve( );
Error_code append(const Queue_entry item);
Error_code retrieve(Queue_entry item) const;
protected: int front,rear; Queue_entry entry [maxqueue];
bool is_empty; };
Queue :: Queue( )
{rear = maxqueue-1; front = 0; is_empty = true;}
bool Queue :: empty( ) const
{return is_empty;}
Error_code Queue :: append(const Queue_entry item)
if (!empty( )&&(rear+1)%maxqueue == front) return overflow;
is_empty = false;
rear=(rear+1)%maxquene;
entry[rear]=item;
return success;
}
Error_code Queue :: serve( )
{
if(empty( ))return underflow;
if(rear==front)is_empty = true;
front=((front+1)==maxqueue)?0:(front+1); return success;
}
Error_code Queue::retrieve(Queue_entry item)
const {
if
(
empty( ))return underflow;
item=entry[front];
return success;
}