Java Program to Implement Merge Sort Algorithm on Linked List

This is a java program to implement merge sort algorithm using linked list.

Here is the source code of the Java Program to Implement Merge Sort Algorithm on Linked List. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.

//This is a java to sort numbers of Linked List using Merge Sort
import java.util.Random;
 
class Node 
{
    public int item;
    public Node next;
 
    public Node(int val) 
    {
        item = val;
    }
 
    public Node() 
    {}
 
    public void displayNode() 
    {
        System.out.print("[" + item + "] ");
    }
}
 
class LinkedList 
{
    private Node first;
 
    public LinkedList() 
    {
        first = null;
    }
 
    public boolean isEmpty() 
    {
        return (first == null);
    }
 
    public void insert(int val)
    {
        Node newNode = new Node(val);
        newNode.next = first;
        first = newNode;
    }
 
    public void append(Node result) 
    {
        first = result;
    }
 
    public void display() 
    {
        Node current = first;
        while (current != null) 
        {
            current.displayNode();
            current = current.next;
        }
        System.out.println("");
    }
 
    public Node extractFirst() 
    {
        return first;
    }
 
    public Node MergeSort(Node headOriginal) 
    {
        if (headOriginal == null || headOriginal.next == null)
            return headOriginal;
        Node a = headOriginal;
        Node b = headOriginal.next;
        while ((b != null) && (b.next != null)) 
        {
            headOriginal = headOriginal.next;
            b = (b.next).next;
        }
        b = headOriginal.next;
        headOriginal.next = null;
        return merge(MergeSort(a), MergeSort(b));
    }
 
    public Node merge(Node a, Node b) 
    {
        Node temp = new Node();
        Node head = temp;
        Node c = head;
        while ((a != null) && (b != null)) 
        {
            if (a.item <= b.item) 
            {
                c.next = a;
                c = a;
                a = a.next;
            }
            else 
            {
                c.next = b;
                c = b;
                b = b.next;
            }
        }
        c.next = (a == null) ? b : a;
        return head.next;
    }
}
 
class Merge_Sort 
{
    public static void main(String[] args) 
    {
        LinkedList object = new LinkedList();
        Random random = new Random();
        int N = 20;
        for (int i = 0; i < N; i++)
            object.insert(Math.abs(random.nextInt(100)));
 
        System.out.println("List items before sorting :");
        object.display();
        object.append(object.MergeSort(object.extractFirst()));
        System.out.println("List items after sorting :");
        object.display();
    }
}

Output:

$ javac Merge_Sort.java
$ java Merge_Sort
 
List items before sorting :
[41] [11] [6] [13] [41] [62] [26] [46] [71] [16] [52] [57] [23] [81] [25] [4] [20] [75] [68] [51] 
List items after sorting :
[4] [6] [11] [13] [16] [20] [23] [25] [26] [41] [41] [46] [51] [52] [57] [62] [68] [71] [75] [81]

Related posts:

Dockerizing a Spring Boot Application
Tạo ứng dụng Java RESTful Client không sử dụng 3rd party libraries
Spring Boot - Tomcat Deployment
Java Program to Solve Travelling Salesman Problem for Unweighted Graph
Logging a Reactive Sequence
Java Program to Implement the Program Used in grep/egrep/fgrep
Notify User of Login From New Device or Location
HashSet trong Java hoạt động như thế nào?
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Practical Java Examples of the Big O Notation
Java Program to Represent Graph Using Adjacency Matrix
Registration with Spring Security – Password Encoding
Java Program to Implement Interval Tree
Java Program to Implement Find all Forward Edges in a Graph
Exploring the New Spring Cloud Gateway
Annotation trong Java 8
Java Program for Topological Sorting in Graphs
Java Program to Implement Hash Tables with Double Hashing
Hướng dẫn Java Design Pattern – Adapter
Unsatisfied Dependency in Spring
Implementing a Binary Tree in Java
Java – InputStream to Reader
Count Occurrences of a Char in a String
Java Program to Generate a Random UnDirected Graph for a Given Number of Edges
New Features in Java 15
Java Program to Implement Ternary Search Algorithm
Java Program to Implement Booth Algorithm
Java Program to Implement Depth-limited Search
Java Program to Implement Karatsuba Multiplication Algorithm
Java Program to Perform Addition Operation Using Bitwise Operators
Mệnh đề Switch-case trong java
Reversing a Linked List in Java