Online Classes

Results can only be achieved if you have the focused direction and crystal clear knowledge. To achieve this, you need a mentor. We will help you out by connecting with an expert mentor in the field.

Learn More

Article

Insert a node after a given node in linked list

2 min 15 sec read

Linked List insertion can be done using three ways,

1) Insertion at front of given node.

2) Insertion after a given node.

3) Insertion at the end of node.

In this tutorial, we consider insertion at front of given node. To understand this look at the following figure,

1) Before Scenario : Insertion after a given node.

1) The original Linked list contains a head pointer pointing to the First Node.

2) First Node points to the second Node.

3) The second Node points to NULL.

 

2) After Scenario: Insertion after a given node.

 

Now if we want to insert a node after a given node of the linked list, it should be like,

1) Head is pointing to the first Node containing value 1.

2) New node next is Pointing to second Node containing value 3.

3) The first node points to the new node containing value 2.

4) The second node points to the third node containing value 4.

5) The third node containing value 4 points to null.

 

Playing with the linked list is a very easy task. Just you should know which node will points to which node. This was the beginning of linked list insertion.

 

Function to insert node after a given node of Linked List :

void insertAfter(struct node* prev_node, int dataValue)
{
  /*1. check if the given prev_node is NULL */
    if (prev_node == NULL) 
    { 
       printf("the given previous node cannot be NULL");       
       return;  
    }  
          
  /* 2. allocate new node */
    struct node* new_node =(struct node*) malloc(sizeof(struct node));
  
  /* 2. put data into new node */
    new_node->data  = dataValue;
  
    /* 4. Make next of new node as next of prev_node */
    new_node->next = prev_node->next; 
  
  /* 5. move the next of prev_node as new_node */
    prev_node->next = new_node;
}

Related Articles

1) How to insert a node at front of a given node in linked list?

2) How to insert a node after a given node in linked list?

3) How to use %5.2f format specifier in C Programming?

4) How to insert a node at the end of linked list?

5) Article on different types of  storage classes in C.

6) C Tutorial on Calloc() vs malloc() functions is explained in depth in this article.

Try to execute what you have learnt

Easy to use online data structure compiler where you can execute the programs in your favourite programming language.
(C, C++, Python)

Open Compiler

HTML, CSS and Javascript Real time Web Editor

Execute your HTML, CSS and javascript code in real time with the web editor
(HTML, CSS, Bootstrap, Javascript)

Open Web Editor