首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >链表递归removeAll方法

链表递归removeAll方法
EN

Stack Overflow用户
提问于 2013-07-02 07:33:55
回答 2查看 2.7K关注 0票数 0

我正在尝试定义一个递归方法,该方法删除单链表中与目标值相等的所有实例。我定义了一个remove方法和一个附带的removeAux方法。我如何改变这一点,以便如果头部需要被移除,头部也被重新分配?这是我到目前为止所知道的:

代码语言:javascript
复制
public class LinkedList<T extends Comparable<T>> {

private class Node {
    private T data;
    private Node next;

    private Node(T data) {
        this.data = data;
        next = null;
    }
}

private Node head;

public LinkedList() {
    head = null;
}

public void remove(T target) {
    if (head == null) {
        return;
    }

    while (target.compareTo(head.data) == 0) {
        head = head.next;
    }

    removeAux(target, head, null);
}

public void removeAux(T target, Node current, Node previous) {
    if (target.compareTo(current.data) == 0) {
        if (previous == null) {
            head = current.next;
        } else {
            previous.next = current.next;
        }
        current = current.next;
        removeAux(target, current, previous); // previous doesn't change

    } else {
        removeAux(target, current.next, current);
    }
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-07-02 07:44:20

当您移除切换到下一个时,我更喜欢传递对前一个的引用,如下所示

代码语言:javascript
复制
public void remove(T target){
   removeAux(target,head, null);
}


public void removeAux(T target, Node current, Node previous) {
      //case base
       if(current == null)
               return;

    if (target.compareTo(current.data) == 0) {

        if (previous == null) {
          // is the head
            head = current.next;
        } else {
            //is not the head
            previous.next = current.next;
        }
        current = current.next;
        removeAux(target, current, previous); // previous doesn't change

    } else {
        removeAux(target, current.next, current);
    }
}

查看此答案graphically linked list可能会帮助您思考如何实现它。如果这对于训练是好的,但你可以用迭代的方式来做。

票数 0
EN

Stack Overflow用户

发布于 2013-07-02 07:53:08

你可以试着设计你的函数,让它像这样工作。

代码语言:javascript
复制
 head = removeAux(target, head); // returns new head

这是我从Coursera的算法类中学不到的一个巧妙技巧。

其余的代码如下所示。

代码语言:javascript
复制
public void removeAux(T target, Node current) {
  //case base
   if(current == null)
           return null;

   current.next = removeAux(target, current.next);

   return target.compareTo(current.data) == 0? current.next: current; // the actual deleting happens here
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/17415285

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档