堆疊是Java語言中最重要的資料結構之一,它的實現,至少應該包括以下幾個方法:
1.pop() 出棧操作,彈出棧頂元素。
2.push(E e) 入堆疊操作
3.peek() 查看棧頂元素
4.isEmpty() 堆疊是否為空
另外,實作一個棧,還應該考慮到幾個問題:
1.堆疊的初始大小以及棧滿以後如何新增堆疊空間
2.對堆疊進行更新時需要進行同步
簡單範例,使用陣列實作棧,程式碼如下:
複製代碼代碼如下:
public class Stack<E> {
// Java 不支援泛型數組,如需使用,請使用Java提供的容器
private Object[] stack;
// 堆疊的預設初始大小
private static final int INIT_SIZE = 2;
// 棧頂索引
private int index;
public Stack() {
stack = new Object[INIT_SIZE];
index = -1;
}
/**
* 建構方法
*
* @param initSize
* 堆疊的初始大小
*/
public Stack(int initSize) {
if (initSize < 0) {
throw new IllegalArgumentException();
}
stack = new Object[initSize];
index = -1;
}
/**
* 出棧操作
*
* @return 堆疊頂對象
*/
public synchronized E pop() {
if (!isEmpty()) {
E temp = peek();
stack[index--] = null;
return temp;
}
return null;
}
/**
* 入堆疊操作
*
* @param obj
* 等待入棧的對象
*/
public synchronized void push(E obj) {
if (isFull()) {
Object[] temp = stack;
// 如果棧滿,則建立空間為目前棧空間兩倍的棧
stack = new Object[2 * stack.length];
System.arraycopy(temp, 0, stack, 0, temp.length);
}
stack[++index] = obj;
}
/**
* 檢視棧頂對象
*
* @return 堆疊頂對象
*/
public E peek() {
if (!isEmpty()) {
return (E) stack[index];
}
return null;
}
/**
* 查看堆疊是否為空
*
* @return 如果堆疊為空回傳true,否則回傳false
*/
public boolean isEmpty() {
return index == -1;
}
/**
* 看棧是否滿
*
* @return 如果堆疊滿載回傳true,否則回傳false
*/
public boolean isFull() {
return index >= stack.length - 1;
}
}
最後說明,Java中實作了棧(java.util.Stack)的資料結構,它是透過繼承Vector類別來實現的,一般情況下我們直接拿來用就行了。