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:
Guide to Dynamic Tests in Junit 5
Introduction to Spring Data REST
Java Program to Implement the Alexander Bogomolny’s UnOrdered Permutation Algorithm for Elements Fro...
Java Program to Implement Circular Singly Linked List
Testing in Spring Boot
HttpAsyncClient Tutorial
Spring @RequestMapping New Shortcut Annotations
Spring Boot - Code Structure
Remove HTML tags from a file to extract only the TEXT
Java Program to Convert a Decimal Number to Binary Number using Stacks
Java Program to Compute Cross Product of Two Vectors
Marker Interface trong Java
How to Get All Spring-Managed Beans?
Java Program to Implement Stein GCD Algorithm
Introduction to Spring Cloud OpenFeign
Java Program to Perform Quick Sort on Large Number of Elements
Java Program to Implement Adjacency List
Redirect to Different Pages after Login with Spring Security
Comparing Long Values in Java
Introduction to Spring MVC HandlerInterceptor
Write/Read cookies using HTTP and Read a file from the internet
LIKE Queries in Spring JPA Repositories
What is a POJO Class?
Java Program to Check Whether a Given Point is in a Given Polygon
Java Program to Find Number of Articulation points in a Graph
A Guide to JPA with Spring
Registration – Password Strength and Rules
Java Program to Implement the MD5 Algorithm
Spring Web Annotations
Introduction to Eclipse Collections
Understanding Memory Leaks in Java
Java Program to Represent Graph Using Adjacency Matrix