Skip to content

Instantly share code, notes, and snippets.

@paullewallencom
Created July 26, 2018 04:40
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save paullewallencom/3c835d1e151dcc4f777ba52ba25589e7 to your computer and use it in GitHub Desktop.
Save paullewallencom/3c835d1e151dcc4f777ba52ba25589e7 to your computer and use it in GitHub Desktop.
Sorts Sequence Using Insertion Sort
import java.util.Comparator;
public class Insertion
{
private Insertion() { }
public static void sort( Comparable[] a )
{
int n = a.length;
for ( int i = 0; i < n; i++ )
{
for ( int j = i; j > 0 && less( a[ j ], a[ j - 1 ] ); j-- )
{
exch( a, j, j - 1 );
}
assert isSorted( a, 0, i );
}
assert isSorted( a );
}
public static void sort( Comparable[] a, int lo, int hi )
{
for ( int i = lo; i < hi; i++ )
{
for ( int j = i; j > lo && less( a[ j ], a[ j - 1 ] ); j-- )
{
exch( a, j, j - 1 );
}
}
assert isSorted( a, lo, hi );
}
public static void sort( Object[] a, Comparator comparator )
{
int n = a.length;
for ( int i = 0; i < n; i++ )
{
for ( int j = i; j > 0 && less( a[ j ], a[ j - 1 ], comparator ); j-- )
{
exch( a, j, j - 1 );
}
assert isSorted( a, 0, i, comparator );
}
assert isSorted( a, comparator );
}
public static void sort( Object[] a, int lo, int hi, Comparator comparator )
{
for ( int i = lo; i < hi; i++ )
{
for ( int j = i; j > lo && less( a[ j ], a[ j - 1 ], comparator ); j-- )
{
exch( a, j, j - 1 );
}
}
assert isSorted( a, lo, hi, comparator );
}
public static int[] indexSort( Comparable[] a )
{
int n = a.length;
int[] index = new int[ n ];
for ( int i = 0; i < n; i++ )
index[ i ] = i;
for ( int i = 0; i < n; i++ )
for ( int j = i; j > 0 && less( a[ index[ j ] ], a[ index[ j - 1 ] ] ); j-- )
exch( index, j, j - 1 );
return index;
}
private static boolean less( Comparable v, Comparable w )
{
return v.compareTo( w ) < 0;
}
private static boolean less( Object v, Object w, Comparator comparator )
{
return comparator.compare( v, w ) < 0;
}
private static void exch( Object[] a, int i, int j )
{
Object swap = a[ i ];
a[ i ] = a[ j ];
a[ j ] = swap;
}
private static void exch( int[] a, int i, int j )
{
int swap = a[ i ];
a[ i ] = a[ j ];
a[ j ] = swap;
}
private static boolean isSorted( Comparable[] a )
{
return isSorted( a, 0, a.length );
}
private static boolean isSorted( Comparable[] a, int lo, int hi )
{
for ( int i = lo+1; i < hi; i++ )
if ( less( a[ i ], a[ i - 1 ] ) ) return false;
return true;
}
private static boolean isSorted( Object[] a, Comparator comparator )
{
return isSorted( a, 0, a.length, comparator );
}
private static boolean isSorted( Object[] a, int lo, int hi, Comparator comparator )
{
for ( int i = lo+1; i < hi; i++ )
if ( less( a[ i ], a[ i - 1 ], comparator ) ) return false;
return true;
}
private static void show( Comparable[] a )
{
for ( int i = 0; i < a.length; i++ )
{
StdOut.println( a[ i ] );
}
}
public static void main( String[] args )
{
String[] a = StdIn.readAllStrings();
Insertion.sort( a );
show( a );
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment