迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

从Java中的链表中删除节点

作者:迹忆客 最近更新:2023/07/19 浏览次数:

本文介绍如何在 Java 中从链表中删除节点。


从Java中的链表中删除节点

链表是Java的util包中的一种数据结构,它实现了链表数据结构。 链表被认为是线性数据结构,其中每个元素都是具有地址和数据部分的单独对象,并且没有元素存储在传染位置中。

从链表中删除节点可以按照删除给定键的第一次出现的过程来完成。

从链表中删除节点的步骤如下:

  • 首先,我们必须找到给定节点的前一个节点。 这意味着在删除节点之前找到该节点。
  • 下一步是更改前一个节点的文本。
  • 最后,我们需要释放可删除节点的内存。

这是一个迭代过程,每个节点都是使用C的malloc()方法动态分配的,因此每次都需要调用free()方法来释放内存。

让我们尝试一个例子,从给定的 Java 链表中删除一个节点:

package jiyik;

public class Example {

    class DemoNode{
        int NodeData;
        DemoNode NextNode;

        public DemoNode(int NodeData) {
            this.NodeData = NodeData;
            this.NextNode = null;
        }
    }

    //head and tail node
    public DemoNode HeadNode = null;
    public DemoNode TailNode = null;

    //to add new nodes
    public void Add_Node(int NodeData) {

        DemoNode NewNode = new DemoNode(NodeData);
        if(HeadNode == null) {
            HeadNode = NewNode;
            TailNode = NewNode;
        }
        else {
            TailNode.NextNode = NewNode;
            TailNode = NewNode;
        }
    }

    //To delete nodes
    public void DeleteNode() {
        if(HeadNode == null) {
            System.out.println("List is empty");
            return;
        }
        else {
            //Checks if the list contains only one element
            if(HeadNode != TailNode ) {
                DemoNode current = HeadNode;
                //Iterate through the list till the second last element
                while(current.NextNode != TailNode) {
                    current = current.NextNode;
                }
                TailNode = current;
                TailNode.NextNode = null;
            }
            else {
                HeadNode = TailNode = null;
            }
        }
    }

    //To display the node
    public void DisplayNode() {

        DemoNode CurrentNode = HeadNode;
        if(HeadNode == null) {
            System.out.println("List is empty");
            return;
        }
        while(CurrentNode != null) {
            System.out.print(CurrentNode.NodeData + " ");
            CurrentNode = CurrentNode.NextNode;
        }
        System.out.println();
    }

    public static void main(String[] args) {

        Example Linked_List = new Example();

        //Adds nodes to the list
        Linked_List.Add_Node(1);
        Linked_List.Add_Node(2);
        Linked_List.Add_Node(3);
        Linked_List.Add_Node(4);

        System.out.println("The Original List is: ");
        Linked_List.DisplayNode();

        while(Linked_List.HeadNode != null) {
            Linked_List.DeleteNode();

            System.out.println("The list after Deleting a Node: ");
            Linked_List.DisplayNode();
        }
    }
}

上面的代码首先将节点添加到链表中,然后从链表末尾删除节点。 查看输出:

The Original List is:
1 2 3 4
The list after Deleting a Node:
1 2 3
The list after Deleting a Node:
1 2
The list after Deleting a Node:
1
The list after Deleting a Node:
List is empty

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

如何在 Java 中延迟几秒钟的时间

发布时间:2023/12/17 浏览次数:217 分类:Java

本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。

如何在 Java 中把 Hashmap 转换为 JSON 对象

发布时间:2023/12/17 浏览次数:187 分类:Java

它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。

如何在 Java 中按值排序 Map

发布时间:2023/12/17 浏览次数:171 分类:Java

本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map 进行排序,并列出了一些示例代码来理解它。

如何在 Java 中打印 HashMap

发布时间:2023/12/17 浏览次数:192 分类:Java

本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。

在 Java 中更新 Hashmap 的值

发布时间:2023/12/17 浏览次数:146 分类:Java

本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。

Java 中的 hashmap 和 map 之间的区别

发布时间:2023/12/17 浏览次数:79 分类:Java

本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,

在 Java 中获取用户主目录

发布时间:2023/12/17 浏览次数:218 分类:Java

这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。

Java 中 size 和 length 的区别

发布时间:2023/12/17 浏览次数:179 分类:Java

这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。

Java 中的互斥锁

发布时间:2023/12/17 浏览次数:111 分类:Java

了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便