从Java中的链表中删除节点
本文介绍如何在 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
相关文章
如何在 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 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,