优先级队列的队尾是不需要改变的,永远在低下标处。当队列增加数据时,队头的位置就是数据项的大小减去1.
public class PriorityQ { private long[] queArray; private int maxSize; private int nItem; public PriorityQ(int s) { maxSize=s; queArray=new long[maxSize]; nItem=0; } //插入 public void insert(long item) { int j;//要插入的位置 if(nItem==0) { //如果一个数据项都没有,直接将item放入数组中 queArray[nItem++]=item; }else { for(j=nItem-1;j>=0;j--) { //从队头开始寻找要插入的位置 if(item>queArray[j]) queArray[j+1]=queArray[j]; else break;//找到位置 } queArray[j+1]=item; nItem++; } } //删除 public long remove() { return queArray[--nItem]; } //获取队头的数据(也是数据项大小最小的) public long peekMin() { return queArray[nItem-1]; } //判断是否为空 public boolean isEmpty() { return nItem==0; } //判断是否是满的 public boolean isFull() { return nItem==maxSize; } }
public class Test { public static void main(String[] args) { PriorityQ thePQ=new PriorityQ(5); thePQ.insert(30); thePQ.insert(50); thePQ.insert(10); thePQ.insert(40); thePQ.insert(20); while(!thePQ.isEmpty()) { long item=thePQ.remove(); System.out.print(item+" "); } } }