为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 java 中创建泛型堆栈 pop 方法

如何在 java 中创建泛型堆栈 pop 方法

慕标5832272 2022-08-03 15:43:37
我目前正在处理一个 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    {    }}}
查看完整描述

2 回答

?
喵喵时光机

TA贡献1846条经验 获得超7个赞

我想通了,我把功劳归于@ScaryWombat。代码是:


public E pop()

{

    if(isEmpty())

    {

        throw new EmptyStackException();

    }

    else

        {

            return elementData[--size];

    }


}


查看完整回答
反对 回复 2022-08-03
?
慕莱坞森

TA贡献1810条经验 获得超4个赞

public E pop()

 {

    E item;


    if(isEmpty())

    {

        throw new EmptyStackException();

    }

    else

    {

        item = elementData[size];

        size--;

    }

    return item;

}

您需要使返回变量等于堆栈数组的顶部,然后递减堆栈数组。此外,您需要通过设置 size=0 来初始化堆栈。


查看完整回答
反对 回复 2022-08-03
  • 2 回答
  • 0 关注
  • 118 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信