java - 删除链表的最后一个节点

标签 java linked-list nodes

我正在练习使用链表节点,遇到了一个我不知道如何回答的问题。你如何删除链表中的最后一个节点。下面的代码适用于最后一个节点的所有条目栏。最后一个不会被删除。

节点类

public class Node {

    private String data;
    private Node next;

    Node(String data, Node next)
    {
        this.data = data;
        this.next = next;
    }

    public void setData(String d)
    {
        data = d;
    }

    public void setNext(Node n)
    {
        next = n;
    }

    public String getData()
    {
        return data;
    }

    public Node getNext()
    {
        return next;
    }

主要

Node list = new Node("NODE 1",new Node("NODE 2",new Node("NODE 3", null)));
        list = insertSecond(list,"New Node");
        list = addLast(list,"LAST NODE");

        printList(list);
        System.out.println();
        deleteNode(list,"LAST NODE");
        printList(list);    
    }

    public static Node deleteNode(Node list,String str)
    {
        Node temp = list;
        Node prev = list;

        while(temp.getNext() != null)
        {
            if(temp.getData().equals(str))
            {
                if(prev.getNext() == null)
                    prev.setNext(null);
                else{
                prev.setNext(prev.getNext().getNext());
                }

            }
            prev = temp;
            temp = temp.getNext();
        }

最佳答案

while(temp != null){
  prev = temp;
  temp = temp.getNext();

}

prev.next = null;

试试这个:

关于java - 删除链表的最后一个节点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15792682/

相关文章:

java - Fragment 和 FragmentList 不显示 Android Studio

java - Wicket 口中的导航 - AjaxPagingNavigator

java - 在 Java 中防止在运行时重写方法

c - 错误 : request for member ‘-----’ in something not a structure or union

javascript - SVG tspan 的outerHTML 替代方案

java - 命名 Java 包的建议方法是什么?

C# 在二叉树节点中存储链表

c - 来自单链表尾部的第 n 个数据

c - 使用链接列表将文件中的单词读取到动态字符中

windows - Windows 节点上的 Kubernetes NAT pod IP