Java Program for Insertion Sort (original) (raw)

Last Updated : 22 Oct, 2024

Insertion sort is a simple sorting algorithm that works the way we sort playing cards in our hands. In this article, we will write the program on Insertion Sort in Java.

Please refer complete article on **Insertion Sort for more details!

Algorithm of Insertion Sort

The algorithm of Insertion Sort is mentioned below:

  1. Variable declared i=1
  2. Traverse the Array till i<N
  1. Return the Sorted Array.

Program of Insertion Sort Java

Below is the implementation of Insertion Sort in Java:

Java `

// Java program for implementation of Insertion Sort

class InsertionSort {

// Function to sort array using insertion sort
void sort(int a[])
{
    int n = a.length;
    for (int i = 1; i < n; ++i) {
        int k = a[i];
        int j = i - 1;

        // Move elements of arr[0..i-1], that are
        // greater than key, to one position ahead
        // of their current position
        while (j >= 0 && a[j] > k) {
            a[j + 1] = a[j];
            j = j - 1;
        }
      
        a[j + 1] = k;
    }
}

public static void main(String args[])
{
    int a[] = { 12, 11, 13, 5, 6 };

    InsertionSort ob = new InsertionSort();
    ob.sort(a);

    int n = a.length;
    for (int i = 0; i < n; ++i)
        System.out.print(a[i] + " ");

}

}

`

The complexity of the above method

**Time Complexity: O(N^2)
**Auxiliary Space: O(1)

Reference

Please refer complete article on Insertion Sort for more details!

Similar Reads

Insertion Sort in Different languages






Binary Insertion Sort in Different languages



Insertion Sort on Linked List




Problem on Insertion Sort