Skip to content

Instantly share code, notes, and snippets.

@paullewallencom
Created July 26, 2018 17:10
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/da3edaac09cac5c62d4226cbd59db333 to your computer and use it in GitHub Desktop.
Save paullewallencom/da3edaac09cac5c62d4226cbd59db333 to your computer and use it in GitHub Desktop.
Shell Sort
public class Shell
{
private Shell() { }
public static void sort( Comparable[] a )
{
int n = a.length;
int h = 1;
while ( h < n / 3 ) h = 3 * h + 1;
while ( h >= 1 )
{
for ( int i = h; i < n; i++ )
{
for ( int j = i; j >= h && less( a[ j ], a[ j - h ] ); j -= h )
{
exch( a, j, j - h );
}
}
assert isHsorted( a, h );
h /= 3;
}
assert isSorted( a );
}
private static boolean less( Comparable v, Comparable w )
{ return v.compareTo( 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 boolean isSorted( Comparable[] a )
{
for ( int i = 1; i < a.length; i++ )
if ( less( a[ i ], a[ i - 1 ] ) ) return false;
return true;
}
private static boolean isHsorted( Comparable[] a, int h )
{
for ( int i = h; i < a.length; i++ )
if ( less( a[ i ], a[ i - h ] ) ) 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();
Shell.sort( a );
show( a );
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment