希爾排序是1959年由D.L.Shell提出來的,相對直接排序有較大的改進。希爾排序又叫縮小增量排序。算法
基本思想:shell
基本思想:算法先將要排序的一組數按某個增量d(n/2,n爲要排序數的個數)分紅若干組,每組中記錄的下標相差d.對每組中所有元素進行直接插入排序,而後再用一個較小的增量(d/2)對它進行分組,在每組中再進行直接插入排序。當增量減到1時,進行直接插入排序後,排序完成。ide
操做方法:spa
一、選擇一個增量序列t1,t2,....,tk,其中ti>tj,tk=1;code
二、按增量序列的個數k,對序列進行k趟排序;blog
三、每趟排序,根據對應的增量ti,將帶排序列分割成若干長度爲m的子序列,分別對個子序列進行直接插入排序。僅增量因子爲1時,整個序列爲一個表來處理,表長度即爲整個序列的長度。排序
希爾排序的示例:it
算法實現:class
咱們簡單處理增量序列:增量序列d = {n/2 ,n/4, n/8 .....1} n爲要排序數的個數
循環
即:先將要排序的一組記錄按某個增量d(n/2,n爲要排序數的個數)分紅若干組子序列,每組中記錄的下標相差d.對每組中所有元素進行直接插入排序,而後再用一個較小的增量(d/2)對它進行分組,在每組中再進行直接插入排序。繼續不斷縮小增量直至爲1,最後使用直接插入排序完成排序。
public class ShellSort3 { public static void main(String[] args) { int[] a = {12,43,65,7632,31,76,21,79,20}; System.out.println("排序前"); for(int i=0; i<a.length; i++){ System.out.print(a[i]+" "); } System.out.println(); shellSort(a, a.length); System.out.println("排序後"); for(int i=0; i<a.length; i++){ System.out.print(a[i]+" "); } } public static void shellSort(int[] a,int n){ int d,x,i,j; d=n/2; //設置增量 while(d>=1){ //當增量小雨1的時候推出循環,說明咱們的數據已經拍好 for(i=d; i<n; i++){ x = a[i]; //獲取序列中的下一個數據,也就是咱們要插入的數據 j = i-d; //序列中的前一個數據 while(j>=0 && x<a[j]){ a[j+d] = a[j]; j -= d; } a[j+d] = x; } d/=2; } } }
希爾排序時效分析很難,關鍵碼的比較次數與記錄移動次數依賴於增量因子序列d的選取,特定狀況下能夠準確估算出關鍵碼的比較次數和記錄的移動次數。目前尚未人給出選取最好的增量因子序列的方法。增量因子序列能夠有各類取法,有取奇數的,也有取質數的,但須要注意:增量因子中除1 外沒有公因子,且最後一個增量因子必須爲1。希爾排序方法是一個不穩定的排序方法。