用于删除链表中节点的Java程序
我们在之前关于单链表的文章中讨论了链表介绍和链表插入。
让我们制定问题陈述以了解删除过程。给定一个“键”,删除链表中该键的第一次出现。
迭代方法:
要从链表中删除一个节点,我们需要执行以下步骤。
1)找到要删除的节点的前一个节点。
2)改变前一个节点的下一个。
3) 为要删除的节点释放内存。
由于链表的每个节点都是使用 C 中的 malloc() 动态分配的,因此我们需要调用 free() 来释放为要删除的节点分配的内存。
Java
// A complete working Java program
// to demonstrate deletion
// in singly linked list
class LinkedList {
Node head; // head of list
/* Linked list Node*/
class Node {
int data;
Node next;
Node(int d)
{
data = d;
next = null;
}
}
/* Given a key, deletes the first
occurrence of key in
* linked list */
void deleteNode(int key)
{
// Store head node
Node temp = head, prev = null;
// If head node itself holds the key to be deleted
if (temp != null && temp.data == key) {
head = temp.next; // Changed head
return;
}
// Search for the key to be deleted, keep track of
// the previous node as we need to change temp.next
while (temp != null && temp.data != key) {
prev = temp;
temp = temp.next;
}
// If key was not present in linked list
if (temp == null)
return;
// Unlink the node from linked list
prev.next = temp.next;
}
/* Inserts a new Node at front of the list. */
public void push(int new_data)
{
Node new_node = new Node(new_data);
new_node.next = head;
head = new_node;
}
/* This function prints contents of linked list starting
from the given node */
public void printList()
{
Node tnode = head;
while (tnode != null) {
System.out.print(tnode.data + " ");
tnode = tnode.next;
}
}
/* Driver program to test above functions. Ideally this
function should be in a separate user class. It is kept
here to keep code compact */
public static void main(String[] args)
{
LinkedList llist = new LinkedList();
llist.push(7);
llist.push(1);
llist.push(3);
llist.push(2);
System.out.println("
Created Linked list is:");
llist.printList();
llist.deleteNode(1); // Delete node with data 1
System.out.println(
"
Linked List after Deletion of 1:");
llist.printList();
}
}
输出:
Created Linked List:
2 3 1 7
Linked List after Deletion of 1:
2 3 7
请参阅链表上的完整文章 |设置 3(删除节点)了解更多详情!