这一章的内容开始多了,怎么说呢,代码都是见过的,但是书中的解析太迷人了。
排序算法类模板 
排序类的算法都会使用两个方法操作数据:less()方法对元素进行比较,exch()方法将元素交换位置。将数据操作限制在这两个方法中使得代码的可读性和可移植性更好。
 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 public  class  SortTemplet      public  static  void  sort (Comparable[] a)       };     private  static  boolean  less (Comparable v, Comparable w)                    return  v.compareTo(w) < 0 ;     }     private  static  void  exch (Comparable[] a, int  i, int  j)                    Comparable t = a[i];         a[i] = a[j];         a[j] = t;     }     private  static  void  show (Comparable[] a)                    for  (int  i = 0 ; i < a.length; i++)             StdOut.print(a[i] + " " );         StdOut.println();     }     public  static  boolean  isSorted (Comparable[] a)                    for  (int  i = 1 ; i < a.length; i++)             if  (less(a[i], a[i - 1 ]))                 return  false ;         return  true ;     }     public  static  void  main (String[] args)           String[] a = In.readString();         sort(a);         assert  isSorted (a)          show(a);     } } 
选择排序 
首先找到数组中最小的元素,其次,将它和数组的第一个元素交换位置。
 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 public  static  class  Selection  extends  SortTemplet           public  static  void  sort (Comparable[] a)                    int  N = a.length;         for  (int  i = 0 ; i < N; i++) {                          int  min = i;                            for  (int  j = i + 1 ; j < N; j++)                 if  (less(a[j], a[min]))                     min = j;             exch(a, i, min);         }     } } 
插入排序 
当前索引左边的元素都是有序的,但他们最终位置还不确定,为了给更小的元素腾出空间,它们可能会被移动。但是当索引到达数组的右端时,数组的排序就完成了。
 
1 2 3 4 5 6 7 8 9 10 11 12 public  static  class  Insertion  extends  SortTemplet           public  static  void  sort (Comparable[] a)                    int  N = a.length;         for  (int  i = 1 ; i < N; i++) {                          for  (int  j = i; j > 0  && less(a[j], a[j - 1 ]); j--)                 exch(a, j, j - 1 );         }     } } 
希尔排序 
对于大规模乱序数组插入排序数组很慢。希尔排序为了加快速度简单地改进了插入排序,交换不相邻的元素以对数组的局部进行排序,并最终用插入排序将局部有序的数组排序。
 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 public  static  class  shell  extends  SortTemplet           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);             }             h = h / 3 ;         }     } } 
FAQ 1.定义一个可比较的数据类型 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 package  FAQ;public  class  Date  implements  Comparable <Date >     private  final  int  day;     private  final  int  month;     private  final  int  year;     public  Date (int  d, int  m, int  y)           day = d;         month = m;         year = y;     }     public  int  day ()           return  day;     }     public  int  month ()           return  month;     }     public  int  year ()           return  year;     }     @Override      public  int  compareTo (Date that)                    if  (this .year > that.year)             return  +1 ;         if  (this .year < that.year)             return  -1 ;         if  (this .month > that.month)             return  +1 ;         if  (this .month < that.month)             return  -1 ;         if  (this .day > that.day)             return  +1 ;         if  (this .day < that.day)             return  -1 ;         return  0 ;     }     public  String toString ()           return  month + "/"  + day + "/"  + year;     } } 
2. 随机生成测试数据测试 1 2 3 4 5 6 7 8 9 10 11 12 13 import  edu.princeton.cs.algs4.StdOut;import  edu.princeton.cs.algs4.StdRandom;public  static  void  main (String[] args)      int  N = 200 ;                                   Integer a[] = new  Integer[N];     for  (int  i = 0 ; i < N; i++)         a[i] = StdRandom.uniform(1 , 100 );           Insertion.sort(a);     assert  isSorted (a)      show(a); }