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 special pointer to remove the required node from the linked list.
Python3
class Node:
def __init__( self , new_data):
self .data = new_data
self . next = None
def deleteLast(head, x):
temp = head
ptr = None
while (temp ! = None ):
if (temp.data = = x):
ptr = temp
temp = temp. next
if (ptr ! = None and ptr. next = = None ):
temp = head
while (temp. next ! = ptr):
temp = temp. next
temp. next = None
if (ptr ! = None and ptr. next ! = None ):
ptr.data = ptr. next .data
temp = ptr. next
ptr. next = ptr. next . next
return head
def newNode(x):
node = Node( 0 )
node.data = x
node. next = None
return node
def display(head):
temp = head
if (head = = None ):
print ( "NULL" )
return
while (temp ! = None ):
print (temp.data, " --> " ,
end = "")
temp = temp. next
print ( "NULL" )
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 )
print ( "Created Linked list: " ,
end = '')
display(head)
head = deleteLast(head, 4 )
print ( "List after deletion of 4: " ,
end = '')
display(head)
|
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.
Python3
class Node:
def __init__( self , data):
self .data = data
self . next = None
def deleteLast(head, key):
x = None
temp = head
while (temp ! = None ):
if (temp.key = = key) :
x = temp
temp = temp. next
if (x ! = None ):
x.key = x. next .key
temp = x. next
x. next = x. next . next
return head
def newNode(key):
temp = Node( 0 )
temp.key = key
temp. next = None
return temp
def printList(node):
while (node ! = None ):
print (node.key,
end = " " )
node = node. next
if __name__ = = '__main__' :
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 )
print ( "Created Linked List: " )
printList(head)
deleteLast(head, 2 )
print ( "Linked List after Deletion of 1: " )
printList(head)
|
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.
Python3
class Node:
def __init__( self , new_data):
self .data = new_data
self . next = None
def deleteLast(head, x):
temp = head
ptr = None
while (temp ! = None ):
if (temp.data = = x):
ptr = temp
temp = temp. next
if (ptr ! = None and ptr. next = = None ):
temp = head
while (temp. next ! = ptr) :
temp = temp. next
temp. next = None
if (ptr ! = None and ptr. next ! = None ):
ptr.data = ptr. next .data
temp = ptr. next
ptr. next = ptr. next . next
return head
def newNode(x):
node = Node( 0 )
node.data = x
node. next = None
return node
def display(head):
temp = head
if (head = = None ):
print ( "None" )
return
while (temp ! = None ):
print (temp.data, " -> " ,
end = "")
temp = temp. next
print ( "None" )
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 )
print ( "Created Linked list: " )
display(head)
head = deleteLast(head, 4 )
print ( "List after deletion of 4: " )
display(head)
|
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!
Feeling lost in the world of random DSA topics, wasting time without progress? It's time for a change! Join our DSA course, where we'll guide you on an exciting journey to master DSA efficiently and on schedule.
Ready to dive in? Explore our Free Demo Content and join our DSA course, trusted by over 100,000 geeks!