我目前正在处理一个 Stack 项目,我正在其中创建一个泛型 Stack 类。我一直在寻找堆栈溢出,但找不到它。我需要帮助在我的代码中创建一个pop方法。
以下是我到目前为止所拥有的:
public class Stack<E>
{
public static final int DEFAULT_CAPACITY = 10;
private E [] elementData;
private int size;
@SuppressWarnings("unchecked")
public Stack()
{
this.elementData = (E[]) new Object[DEFAULT_CAPACITY];
}
@SuppressWarnings("unchecked")
public Stack(int capacity)
{
if(capacity < 0)
{
throw new IllegalArgumentException("capacity " + capacity);
}
this.elementData = (E[]) new Object[capacity];
}
public boolean isEmpty()
{
if(size == 0)
{
return true;
}
else
{
return false;
}
}
/*
The push method should add its parameter to the top of the stack.
*/
public void push(E item)
{
ensureCapacity(size+1);
elementData[size] = item;
size++;
}
private void ensureCapacity(int capacity)
{
if(elementData.length < capacity)
{
int newCapacity = elementData.length * 2 + 1;
elementData = Arrays.copyOf(elementData, newCapacity);
}
}
我在这里需要帮助。我需要让pop方法删除并返回堆栈顶部的元素。如果不存在任何项目,它应该抛出一个“EmptyStackException”。
public E pop()
{
if(isEmpty())
{
throw EmptyStackException
}
else
{
}
}
}
喵喵时光机
慕莱坞森
相关分类