In this tutorial, we will learn a very basic Java interview question that is how to insert an element in a sorted linked list so that the linked list remains sorted after the insertion of the new element.

Also, we will see how we can insert an element at the beginning of the list.

Confused, what is the problem statement is? Let’s understand this with the help of sample input and output.

## Problem Statement

Let’s suppose we have a sorted linked list and value given to insert in the linked list. We have to insert a given element in the linked list in such a way so that the linked list remains sorted after the insertion of the new element.

Below given is our sample input for the **sorted insert linked list** problem.

Suppose we have to add an element with the value 23 to it. We need to insert the new elements in such a way so that our linked list remains sorted. So, the position of 23 will be after the node with value 20 and before a node with value 30.

Below is the output after we insert element 23 to our linked list.

Let’s see an algorithm to solve this problem.

### Algorithm to Solve Sorted Insert in Linked List Problem

Below is the step-by-step information to solve the problem of the sorted insert.

- If our linked list is initially empty, then make the new node as head and return new node.
- If the value of node to be inserted is less than the value of the head node then inserts the new node at the start and make it head.
- Otherwise, if above given conditions are not true then find the appropriate node after which the input node is to be inserted. In our case since we are going to insert 23 so appropriate node will be 20 because after 20, we will insert the 23. To find the appropriate node we will start from the head and keep moving until we reach the value greater than the node which need to be inserted. In our case the node which has greater value than the insertion node is node with value 30. So, node before this node is appropriate node ( here node with value 20).
- Now we simply insert the node with value 23 in the sorted linked list. So new node will be next of current node ( i.e., node with value 20).

```
private static Node sortedInsertInLinkedList(Node head, int data) {
Node newNode = new Node(data);
if (head == null) {
return newNode;
}else if (head.data > data){
newNode.next = head;
return newNode;
}
Node curr = head;
Node prev = null;
while (curr.next != null && curr.next.data < data) {
curr = curr.next;
}
Node temp = curr.next;
curr.next = newNode;
newNode.next = temp;
return head;
}
```

Below is the complete code for solving this problem with the output.

```
package com.codezup.singlylinkedlist;
import java.util.Scanner;
public class SortedInsertLinkedList {
public static void main(String[] args) {
Node head = null;
head = insertAtBeginingLinkedList(head, 40);
head = insertAtBeginingLinkedList(head, 35);
head = insertAtBeginingLinkedList(head, 30);
head = insertAtBeginingLinkedList(head, 20);
head = insertAtBeginingLinkedList(head, 10);
System.out.println("Linked List elements are:");
printLinkedList(head);
System.out.println("\nNow we are adding element in sorted linked list");
System.out.println("Enter elements which you want to add in sorted linked list");
Scanner scanner = new Scanner(System.in);
int data = scanner.nextInt();
head = sortedInsertInLinkedList(head, data);
System.out.println("Linked list after sorted insert of element:" + data);
printLinkedList(head);
}
private static Node sortedInsertInLinkedList(Node head, int data) {
Node newNode = new Node(data);
if (head == null) {
return newNode;
}else if (head.data > data){
newNode.next = head;
return newNode;
}
Node curr = head;
Node prev = null;
while (curr.next != null && curr.next.data < data) {
curr = curr.next;
}
Node temp = curr.next;
curr.next = newNode;
newNode.next = temp;
return head;
}
private static void printLinkedList(Node head) {
if (head != null) {
System.out.print(head.data + " ");
printLinkedList(head.next);
}
}
private static Node insertAtBeginingLinkedList(Node head, int data) {
Node newNode = new Node(data);
if (head == null) {
return newNode;
}
newNode.next = head;
return newNode;
}
}
```

### Output

```
Linked List elements are:
10 20 30 40
Now we are adding element in sorted linked list
Enter elements which you want to add in sorted linked list
23
Linked list after sorted insert of element:23
10 20 23 30 40
```

#### Conclusion

The time complexity for this solution is **O(n)** because only one traversal is required of the list. And since no extra space is needed to implement this solution so it takes **O(1)** auxiliary space.

That’s all for this tutorial. Hope you like the tutorial and find this informative. Please share this tutorial with others if you find this informative and comment on your thoughts in the comment section down below.

Happy Learning.