主类
package DataStructures;
public class ArrayStack {
private Object[] theArray;
private int topOfStack;
static final int DEFAULT_CAPACITY = 10;
/**
* Construct the stack.
*
*/
public ArrayStack() {
this(DEFAULT_CAPACITY);
}
/**
* Construct the stack.
*
* @param capacity
* teh capacity.
*/
public ArrayStack(int capacity) {
}
public boolean IsEmpty() {
return topOfStack == -1;
}
public boolean IsFull() {
return topOfStack == theArray.length - 1;
}
public void MakeEmpty() {
topOfStack = -1;
}
/**
* Insert a new item into the stack, if not already full.
*
* @param x
* th item to insert.
* @throws Overflow
* if stack is already full.
*/
public void Push(Object x) throws Overflow {
if (IsFull())
throw new Overflow();
theArray[++topOfStack] = x;
}
/**
* Get the most recently inserted item in the stack. Dos not alter the
* stack.
*
* @return the most recently inserted item, or null, if empty.
*/
public Object Top() {
if (IsEmpty())
return null;
return theArray[topOfStack];
}
public void Pop() throws Underflow {
if (IsEmpty())
throw new Underflow();
theArray[topOfStack--] = null;
}
/**
* Return and remove most recently inserted item form the stack.
*
* @return most recently inserted item, or null, if stack is empty.
*/
public Object TopAndPop() {
if (IsEmpty())
return null;
Object topItem = Top();
theArray[topOfStack--] = null;
return topItem;
}
}
异常类
public class ArrayStack {
private Object[] theArray;
private int topOfStack;
static final int DEFAULT_CAPACITY = 10;
/**
* Construct the stack.
*
*/
public ArrayStack() {
this(DEFAULT_CAPACITY);
}
/**
* Construct the stack.
*
* @param capacity
* teh capacity.
*/
public ArrayStack(int capacity) {
}
public boolean IsEmpty() {
return topOfStack == -1;
}
public boolean IsFull() {
return topOfStack == theArray.length - 1;
}
public void MakeEmpty() {
topOfStack = -1;
}
/**
* Insert a new item into the stack, if not already full.
*
* @param x
* th item to insert.
* @throws Overflow
* if stack is already full.
*/
public void Push(Object x) throws Overflow {
if (IsFull())
throw new Overflow();
theArray[++topOfStack] = x;
}
/**
* Get the most recently inserted item in the stack. Dos not alter the
* stack.
*
* @return the most recently inserted item, or null, if empty.
*/
public Object Top() {
if (IsEmpty())
return null;
return theArray[topOfStack];
}
public void Pop() throws Underflow {
if (IsEmpty())
throw new Underflow();
theArray[topOfStack--] = null;
}
/**
* Return and remove most recently inserted item form the stack.
*
* @return most recently inserted item, or null, if stack is empty.
*/
public Object TopAndPop() {
if (IsEmpty())
return null;
Object topItem = Top();
theArray[topOfStack--] = null;
return topItem;
}
}
package DataStructures;
/**
* Exception class for access in full containers such as stacks, queues, and
* priority queues.
*/
public class Overflow extends Exception {
}
/**
* Exception class for access in full containers such as stacks, queues, and
* priority queues.
*/
public class Overflow extends Exception {
}
本文转自冬冬博客园博客,原文链接:http://www.cnblogs.com/yuandong/archive/2006/08/23/484641.html
,如需转载请自行联系原作者