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:
Java Program for Douglas-Peucker Algorithm Implementation
Converting Java Date to OffsetDateTime
Java Program to Implement Maximum Length Chain of Pairs
Spring RestTemplate Error Handling
RegEx for matching Date Pattern in Java
Java Program to Check Cycle in a Graph using Topological Sort
Java Program to Implement Selection Sort
Dijkstra's Algorithm
Java Program to Implement Efficient O(log n) Fibonacci generator
A Guide to JUnit 5
Java Program to Implement Segment Tree
Sorting in Java
Primitive Type Streams in Java 8
Assertions in JUnit 4 and JUnit 5
Send an email with an attachment
Hướng dẫn sử dụng Java Reflection
Lớp LinkedHashMap trong Java
Spring Boot - Actuator
Java Timer
Java Program to Implement Gift Wrapping Algorithm in Two Dimensions
Spring Boot - Cloud Configuration Client
Spring Boot - Database Handling
Runnable vs. Callable in Java
Spring WebClient Requests with Parameters
Java Program to Implement Binary Heap
Java – Try with Resources
Jackson JSON Views
Interface trong Java 8 – Default method và Static method
HttpClient 4 – Send Custom Cookie
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
Finding Max/Min of a List or Collection
Java Program to Implement Interval Tree