Java Program For Deleting Last Occurrence Of An Item From Linked List
Last Updated :
22 Jun, 2022
Using pointers, loop through the whole list and keep track of the node prior to the node containing the last occurrence key using a special pointer. After this just store the next of next of the special pointer, into to next of special pointer to remove the required node from the linked list.
Java
// Java program to implement
// the above approach
import java.io.*;
// A linked list Node
class Node
{
int data;
Node next;
Node(int data)
{
this.data = data;
this.next = null;
}
}
class GFG{
// Function to delete the last
// occurrence
static Node deleteLast(Node head,
int x)
{
Node temp = head;
Node ptr = null;
while (temp != null)
{
// If found key, update
if (temp.data == x)
ptr = temp;
temp = temp.next;
}
// If the last occurrence is the
// last node
if (ptr != null &&
ptr.next == null)
{
temp = head;
while (temp.next != ptr)
{
temp = temp.next;
}
temp.next = null;
}
// If it is not the last node
if (ptr != null &&
ptr.next != null)
{
ptr.data = ptr.next.data;
temp = ptr.next;
ptr.next = ptr.next.next;
}
return head;
}
// This function prints contents of
// linked list starting from the given
// Node
static void display(Node head)
{
Node temp = head;
if (head == null)
{
System.out.print("NULL");
return;
}
while (temp != null)
{
System.out.print(temp.data +
" --> ");
temp = temp.next;
}
System.out.print("NULL");
}
// Driver code
public static void main(String[] args)
{
Node head = new Node(1);
head.next = new Node(2);
head.next.next = new Node(3);
head.next.next.next =
new Node(4);
head.next.next.next.next =
new Node(5);
head.next.next.next.next.next =
new Node(4);
head.next.next.next.next.next.next =
new Node(4);
System.out.print(
"Created Linked list: ");
display(head);
// Pass the address of the head
// pointer
head = deleteLast(head, 4);
System.out.print(
"List after deletion of 4: ");
display(head);
}
}
// This code is contributed by patel2127
Output:
Created Linked list: 1 --> 2 --> 3 --> 4 --> 5 --> 4 --> 4 --> NULL
List after deletion of 4: 1 --> 2 --> 3 --> 4 --> 5 --> 4 --> NULL
Time Complexity: O(n) where n is the number of nodes in the given linked list.
Auxiliary Space: O(1), no extra space is required, so it is a constant.
Given a linked list and a key to be deleted. Delete last occurrence of key from linked. The list may have duplicates.
Examples:
Input: 1->2->3->5->2->10, key = 2
Output: 1->2->3->5->10
The idea is to traverse the linked list from beginning to end. While traversing, keep track of last occurrence key. After traversing the complete list, delete the last occurrence by copying data of next node and deleting the next node.
Java
// A Java program to demonstrate deletion
// of last Node in singly linked list
class GFG{
// A linked list Node
static class Node
{
int key;
Node next;
};
static Node deleteLast(Node head,
int key)
{
// Initialize previous of Node to
// be deleted
Node x = null;
// Start from head and find the Node
// to be deleted
Node temp = head;
while (temp != null)
{
// If we found the key,
// update xv
if (temp.key == key)
x = temp;
temp = temp.next;
}
// Key occurs at-least once
if (x != null)
{
// Copy key of next Node to x
x.key = x.next.key;
// Store and unlink next
temp = x.next;
x.next = x.next.next;
// Free memory for next
}
return head;
}
// Utility function to create a
// new node with given key
static Node newNode(int key)
{
Node temp = new Node();
temp.key = key;
temp.next = null;
return temp;
}
// This function prints contents of
// linked list starting from the given
// Node
static void printList( Node node)
{
while (node != null)
{
System.out.printf(" %d ",
node.key);
node = node.next;
}
}
// Driver code
public static void main(String args[])
{
// Start with the empty list
Node head = newNode(1);
head.next = newNode(2);
head.next.next = newNode(3);
head.next.next.next =
newNode(5);
head.next.next.next.next =
newNode(2);
head.next.next.next.next.next =
newNode(10);
System.out.printf("Created Linked List: ");
printList(head);
deleteLast(head, 2);
System.out.printf(
"Linked List after Deletion of 1: ");
printList(head);
}
}
// This code is contributed by Arnab Kundu
Output:
Created Linked List:
1 2 3 5 2 10
Linked List after Deletion of 1:
1 2 3 5 10
Time Complexity: O(n) where n is the number of nodes in the given linked list.
Auxiliary Space: O(1), no extra space is required, so it is a constant.
The above solution doesn't work when the node to be deleted is the last node.
Following solution handles all cases.
Java
// Java program to demonstrate deletion
// of last Node in singly linked list
class GFG{
// A linked list Node
static class Node
{
int data;
Node next;
};
// Function to delete the last
// occurrence
static void deleteLast(Node head,
int x)
{
Node temp = head, ptr = null;
while (temp!=null)
{
// If found key, update
if (temp.data == x)
ptr = temp;
temp = temp.next;
}
// If the last occurrence is the
// last node
if (ptr != null &&
ptr.next == null)
{
temp = head;
while (temp.next != ptr)
temp = temp.next;
temp.next = null;
}
// If it is not the last node
if (ptr != null &&
ptr.next != null)
{
ptr.data = ptr.next.data;
temp = ptr.next;
ptr.next = ptr.next.next;
System.gc();
}
}
/* Utility function to create a
new node with given key */
static Node newNode(int x)
{
Node node = new Node();
node.data = x;
node.next = null;
return node;
}
// This function prints contents
// of linked list starting from
// the given Node
static void display(Node head)
{
Node temp = head;
if (head == null)
{
System.out.print("null");
return;
}
while (temp != null)
{
System.out.printf("%d --> ",
temp.data);
temp = temp.next;
}
System.out.print("null");
}
// Driver code
public static void main(String[] args)
{
Node head = newNode(1);
head.next = newNode(2);
head.next.next = newNode(3);
head.next.next.next =
newNode(4);
head.next.next.next.next =
newNode(5);
head.next.next.next.next.next =
newNode(4);
head.next.next.next.next.next.next =
newNode(4);
System.out.print(
"Created Linked list: ");
display(head);
deleteLast(head, 4);
System.out.print(
"List after deletion of 4: ");
display(head);
}
}
// This code is contributed by PrinciRaj1992
Output:
Created Linked List:
1 2 3 4 5 4 4
Linked List after Deletion of 1:
1 2 3 4 5 4
Time Complexity: O(n) where n is the number of nodes in the given linked list.
Auxiliary Space: O(1), no extra space is required, so it is a constant.
Please refer complete article on Delete last occurrence of an item from linked list for more details!
Similar Reads
Java Program For Deleting A Node In A Linked List We have discussed Linked List Introduction and Linked List Insertion in previous posts on a singly linked list.Let us formulate the problem statement to understand the deletion process. Given a 'key', delete the first occurrence of this key in the linked list. Iterative Method:To delete a node from
3 min read
Java Program For Deleting A Node In A Doubly Linked List Pre-requisite: Doubly Link List Set 1| Introduction and Insertion Write a function to delete a given node in a doubly-linked list. Original Doubly Linked List Recommended: Please solve it on "PRACTICE" first, before moving on to the solution. Approach: The deletion of a node in a doubly-linked list
4 min read
Java Program For Deleting A Linked List Node At A Given Position Given a singly linked list and a position, delete a linked list node at the given position. Example: Input: position = 1, Linked List = 8->2->3->1->7 Output: Linked List = 8->3->1->7 Input: position = 0, Linked List = 8->2->3->1->7 Output: Linked List = 2->3->1
3 min read
Java Program For Removing All Occurrences Of Duplicates From A Sorted Linked List Given a sorted linked list, delete all nodes that have duplicate numbers (all occurrences), leaving only numbers that appear once in the original list. Examples: Input: 23->28->28->35->49->49->53->53 Output: 23->35 Input: 11->11->11->11->75->75 Output: empty List Note that this is different from Rem
3 min read
Remove First and Last Elements from LinkedList in Java The Java.util.LinkedList.removeFirst() method is used to remove the first element from the LinkedList. The Java.util.LinkedList.removeLast() method is used to remove the last element from the LinkedList. Both the methods also returns the element after removing it. 1. removeFirst() Syntax: LinkedList
2 min read
Java Program to Get the First and the Last Element of a Linked List A linked list is a linear data structure, in which the elements are not stored at contiguous memory locations. The given task is to retrieve the first and the last element of a given linked list. Properties of a Linked ListElements are stored in a non-contiguous manner.Every element is an object whi
4 min read
Java Program to Delete a Node From the Ending of the Circular Linked List In this article, we will learn about deleting a node from the ending of a circular linked list. Consider the linked list as shown below:Â Example:Input : 5->3->4->(head node)Output: 5->3->(head node)We will first initialize the list and add some data into it with the addNode() method a
3 min read
Java Program To Delete Alternate Nodes Of A Linked List Given a Singly Linked List, starting from the second node delete all alternate nodes of it. For example, if the given linked list is 1->2->3->4->5 then your function should convert it to 1->3->5, and if the given linked list is 1->2->3->4 then convert it to 1->3. Recomm
3 min read
Java Program For Deleting A Given Node In Linked List Under Given Constraints Given a Singly Linked List, write a function to delete a given node. Your function must follow the following constraints: It must accept a pointer to the start node as the first parameter and node to be deleted as the second parameter i.e., a pointer to the head node is not global.It should not retu
3 min read
Java Program To Delete Middle Of Linked List Given a singly linked list, delete the middle of the linked list. For example, if the given linked list is 1->2->3->4->5 then the linked list should be modified to 1->2->4->5 If there are even nodes, then there would be two middle nodes, we need to delete the second middle element. For example, if g
4 min read