如何在Java中删除单链表中的重复元素?

格雷格

我已经实现了自己的单链接列表,但是在删除列表中的重复元素时遇到了问题。这是我的实现:

List.java:

public class List {
private Element first;
private int size;

public void removeRepetitive()
{
    Element e1 = first;
    Element e2 = e1.getNext();

    while(e1.getNext() != null && e2.getNext() != null)
    {
        while(e2.getNext() != null)
        {
            if(e1.getCard().equals(e2.getCard()))
            {
                remove(e2.getCard());

            }
            e2 = e2.getNext();
        }
        e1 = e1.getNext();
        e2 = e1.getNext();
    }
}
}

Element.java:

package lists;

public class Element {
private Karta karta;
private Element next;

public Element(Karta k)
{
    karta = k;
    next = null;
}
public Element(Karta k, Element e)
{
    karta = k;
    next = e;
}
public Karta getCard()
{
    return karta;
}
public Element getNext()
{
    return next;
}
public void setNext(Element e)
{
    next = e;
}
public void setCard(Karta k)
{
    karta = k;
}

我设法编写了简单的删除方法,但在此示例中一直遇到NullPointerException。我已经尝试了所有方法,这是我方法的最新版本。谁能帮我或者至少说明应该怎么做?

卢加里

当您尝试在已删除的节点上运行getNext时,就会发生NPE。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章