数据结构与程序设计 练习3.3 E7

来源:互联网 发布:matlab机器人仿真软件 编辑:程序博客网 时间:2024/06/03 21:38

数据结构与程序设计 练习3.3 E7

 

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 = -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 ) == maxqueue ) ? 0 : (rear + 1) ;

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 ;

 

原创粉丝点击