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 to Perform Postorder Non-Recursive Traversal of a Given Binary Tree
Rate Limiting in Spring Cloud Netflix Zuul
Cachable Static Assets with Spring MVC
Java Program to Implement the MD5 Algorithm
Tránh lỗi NullPointerException trong Java như thế nào?
Guide to the Java Clock Class
Biến trong java
Java Program to Perform Insertion in a 2 Dimension K-D Tree
Mapping a Dynamic JSON Object with Jackson
Java 8 and Infinite Streams
How to Remove the Last Character of a String?
StringBuilder vs StringBuffer in Java
Hướng dẫn Java Design Pattern – Builder
An Intro to Spring Cloud Security
Java Program to Implement Interval Tree
Generating Random Numbers in a Range in Java
Receive email using IMAP
Mix plain text and HTML content in a mail
Number Formatting in Java
Java Program to Implement Gale Shapley Algorithm
Period and Duration in Java
Spring Boot - Web Socket
Introduction to Apache Commons Text
Java Program to Implement Hash Tables with Linear Probing
Chương trình Java đầu tiên
Java Program to Implement Fibonacci Heap
Add Multiple Items to an Java ArrayList
Java Program to Check Whether a Given Point is in a Given Polygon
Java – Random Long, Float, Integer and Double
Java Program to Find Nearest Neighbor Using Linear Search
Preparing for Merge Sort
The Registration Process With Spring Security