Skip to main content

Insertion and Deletion of a Node in Linked List | Java | MyCodingNetwork

 


Insertion of a new node & Deletion of an existing node


After an exhilarating commencement of the Linked List series, in this post, we'll be exploring the artistry behind insertion and deletion operations in linked list. So let's now move on to the second problem statement of the series, i.e., write two functions for insertion and deletion of a node respectively, from linked list.

Algorithm for inserting a node at pos position:

  1. Create a function insert () which takes head of the node, pos and the new node as the parameter.
  2. Take a base case, if pos==1, means the new node is to be made the head of the linked list.
  3. If the above case is not true, traverse the linked list and reach to position, pos-1.
  4. Assign the new node with the address of the node at pos.
  5. Finally, assign the node at pos-1 with address of new node.

Algorithm for deleting a node at pos position:

  1. Create a function deletion () which takes pos and the head of the LinkedList as parameter.
  2. Base case, if pos ==1, then assign the second element as the head and return the new head.
  3. Traverse the linked list till the node at pos-1.
  4. Assign the node at pos-1 with the address of node with address of the node at pos+1.

Source Code with Explanation:


Insert() function: 




It is the function that inserts a new node `nn` into a linked list at a given position `pos`. The method takes three arguments: the head of the linked list `head`, the position `pos` where the new node `nn` should be inserted, and the new node `nn` itself.

The method first checks if the given position is 1. If it is, the method sets the next pointer of the new node to the current head of the list, calls a method named `traverse` with the new node as an argument, and returns the new node as the new head of the list.

If the given position is not 1, the method iterates through the list until it reaches the node before the desired position. It then sets the next pointer of the new node to the next node of the current node and sets the next pointer of the current node to the new node. Finally, it returns the head of the list.

Note: It's important to note that this code assumes that the given position is valid and within the bounds of the list.

Time Complexity: The time complexity of the insert() function is O(n). The for loop in the function runs for `pos-1` times where `pos` is the position at which the new node `nn` is to be inserted. In the worst-case scenario, `pos` can be equal to the length of the linked list, making the time complexity O(n).




Deletion() function:




It is a method for deleting a node from a linked list at a specified position. The method takes two arguments: `head`, which is the head of the linked list, and `pos`, which is the position of the node to be deleted.

First, the method creates a new `Node` object called `cur` and sets it equal to the `head` of the linked list. If the position to be deleted is 1 (i.e., the first node in the list), then the method sets the `head` of the list to be the next node in the list.

If the position to be deleted is not 1, then the method enters a `for` loop that iterates from 1 to `pos-1`. In each iteration of the loop, `cur` is set to be the next node in the list. After the loop completes, `cur` is pointing to the node immediately before the node to be deleted. The method then sets the `next` field of `cur` to be equal to the node after the node to be deleted.

Finally, after either deleting the first node or deleting a node at some other position in the list, the method calls a function named `traverse(head)` which traverses and prints out all elements of the linked list starting from its head.

Time Complexity: The time complexity of the deletion() function is O(n). The reason is somewhat similar to that of insert() function. In worst case scenario, the for loop will traverse the full length of the linked list, , making the time complexity O(n).

Full source code link: Source Code | Insertion and Deletion of Linked List | MyCodingNetwork

Output:



The first line is the original Linked List.
The second line is after insertion operation is performed, 50 is added at 3rd position.
The third line is after deletion operation is performed, first element is deleted.

Video References:





Hope you liked this explanation, for any feedback or doubt you can comment down in the comment section.

Popular posts from this blog

Pattern 2 | Java

  Problem Statement: Write a program to draw the following pattern: * * * * * * * * * * * * * * * (take a variable n which decides the number of rows, for above example, n=5) THE CODE Output: *  * *  * * *  * * * *  * * * * *  * * * * * *          * * * * * * *        * * * * * * * *      * * * * * * * * *    * * * * * * * * * * Simplification : In the above problem, the value of n is 10 (i.e., the number of rows are 10) 1. In the first for loop we have i as the counter variable with initial value of 1 and having a condition i.e. i should be less than or equal to n.  It has a print statement after the second for loop,  System.out.println(); w hich is used for changing the row, each time for the second for loop terminates. 2. In the second for loop we have j as the counter variable with initial value of 1 having a condition i.e. j  should be  less than or equal to i (the value of i  will be as per the current ongoing iteration). Further it has an updation statement j++  Inside the seco

Code #1 | Hello Java | Basics of Java

Today starting with a very basic coding program in Java. So, the program is Write a program in Java to print "Hello Java!" Output: Hello Java!

Bubble Sort | Java & Python | MyCodingNetwork | Alok Tripathi

  Bubble Sort is a simple sorting algorithm that works by repeatedly comparing and swapping adjacent elements in an array until they are in the correct order. It is called bubble sort because the smaller elements "bubble" to the top of the array, while the larger elements sink to the bottom. Quick Video Explanation: How Bubble Sort Works Bubble sort works by iterating through the array from left to right and comparing each pair of adjacent elements. If the element on the left is larger than the element on the right, they are swapped. This way, the largest element in the array moves to the rightmost position in each iteration. This process is repeated until no more swaps are needed, which means the array is sorted. To illustrate how bubble sort works, let's use the example of sorting the array [30,90,50,10,40] in ascending order. First Iteration/Pass: The first step is to compare the first two elements, 30 and 90. Since 30 is smaller than 90, they are already i