Remove Node From a Linked List In Python

Author: Al-mamun Sarkar Date: 2020-03-28 14:51:14

Remove Node From a Linked List In Python. The following code shows how to remove a node from a linked list in the Python programming language. 

Code:

class Node:
    def __init__(self, data=None):
        self.data = data
        self.next = None


class SLinkedList:
    def __init__(self):
        self.head = None

    def print_list(self):
        print_val = self.head
        while print_val is not None:
            print(print_val.data)
            print_val = print_val.next

    def add_at_beginning(self, new_data):
        new_node = Node(new_data)
        new_node.next = self.head
        self.head = new_node

    def add_at_end(self, new_data):
        new_node = Node(new_data)
        if self.head is None:
            self.head = new_node
            return
        temp_val = self.head
        while temp_val.next:
            temp_val = temp_val.next
        temp_val.next = new_node

    def add_in_middle(self, middle_node, new_data):
        new_node = Node(new_data)
        new_node.next, middle_node.next = middle_node.next, new_node

    def remove_node(self, remove_data):
        head_val = self.head

        # Remove if data is the first element
        if head_val is not None:
            if head_val.data == remove_data:
                self.head = head_val.next
                head_val = None
                return

        # find out the data node and previous node
        while head_val is not None:
            if head_val.data == remove_data:
                break
            prev = head_val
            head_val = head_val.next

        # Return if head val is empty
        if head_val == None:
            return

        # Remove item from linked list
        prev.next = head_val.next
        head_val = None


if __name__ == "__main__":
    linked_list = SLinkedList()
    linked_list.head = Node("Sat")

    e1 = Node("Sun")
    e2 = Node("Mon")

    linked_list.head.next = e1
    e1.next = e2
    linked_list.add_at_beginning('Welcome')
    linked_list.add_at_end('Dhaka')
    linked_list.add_in_middle(e2, 'Mid')

    print("Before Remove")
    linked_list.print_list()

    print("After Remove")
    linked_list.remove_node('Mon')
    linked_list.print_list()

 

Output:

Before Remove
Welcome
Sat
Sun
Mon
Mid
Dhaka
After Remove
Welcome
Sat
Sun
Mid
Dhaka