//package DataStructures; /** * Interface for a priority queue.

* * The remove method returns an item of highest priority from * the queue.

* * If distinct items are of the same priority, an implementation is * not obliged to return them in any particular order, unless it * declares otherwise.

* * @author Peter Williams * @see Comparable */ public interface PriorityQueue { /** * Indicates the status of the queue. * @return true if the queue is empty. */ public boolean isEmpty(); /** * Returns the current size of the queue * @return the current size of the queue */ public int size(); /** * Adds an item to the queue. * @param item the item to be added. */ public void add(Comparable item); /** * Removes an item of highest priority from the queue. * @return an item of highest priority. * @exception NoSuchElementException if the queue is empty. */ public Comparable remove(); }