exercise3.3

E7

 

question :

 rewrite the methods for queue processing from the text , using a flag to indicate a full queue instead of keeping a count of the entries in the queue.

 

answer :

#include<iostream>
#include<queue>
using namespace std;
#include"Queue.cpp"
typedef int Queue_entry;
enum Error_code(success,underflow,overflow);
int main()
{
 const int maxq=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;

  int rear;
  int flag;
  Queue_entry[maxqueue];
 }
 Queue::Queue()
 {
  flag=1;
  rear=maxqueue-1;
  front=0;
 }
 bool Queue::empty()const
 {
  return flag=1;
 }
 Error_code Queue::append(const Queue_entry &item)
 {
  if(flag==1)
  {
   rear=(rear+1)%maxqueue;
   entry[rear]=item;
   return success;
  }
  else return overflow;
 }
 Error_code Queue::serve()
 {
  if(flag!=1)
  {
   front=(front+1)%maxqueue;
   return success;
  }
  else return underflow;
 }
 Error_code Queue::retrieve(Queue_entry&item)const
 {
  if(flag!=1)
  {
   item=entry[front];
   return success;
  }
  else return underflow;
 }

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值