如何編寫一個JAVA的隊列類?下面是由本站小編為大家整理的編寫一個JAVA的隊列類,喜歡的可以收藏一下!瞭解更多詳情資訊,請關注應屆畢業生考試網!
根據這些特點,對隊列定義了以下六種操作:
enq(x) 向隊列插入一個值為x的元素;
deq() 從隊列刪除一個元素;
front() 從隊列中讀一個元素,但隊列保持不變;
empty() 判斷隊列是否為空,空則返回真;
clear() 清空隊列;
search(x) 查找距隊首最近的元素的`位置,若不存在,返回-1。
Vector類是JAVA中專門負責處理對象元素有序存儲和任意增刪的類,因此,用Vector
可以快速實現JAVA的隊列類。
public class Queue extends java
public synchronized void enq(ob ject x) {
lement(x);
}
public synchronized ob ject deq() {
/* 隊列若為空,引發EmptyQueueException異常 */
if( y() )
throw new EmptyQueueException();
ob ject x = entAt(0);
veElementAt(0);
return x;
}
public synchronized ob ject front() {
if( y() )
throw new EmptyQueueException();
return entAt(0);
}
public boolean empty() {
return pty();
}
public synchronized void clear() {
veAllElements();
}
public int search(ob ject x) {
return xOf(x);
}
}
public class EmptyQueueException extends java
}
以上程序在JDK1.1.5下編譯通過