希爾排序及其分析

2021-06-22 21:58:41 字數 558 閱讀 7944

希爾排序另一種叫法叫做縮減增量排序

演算法實現:

public static > void shellsort(anytype a){

int j;

for(int gap=a.length/2;gap>0;gap/=2){

for(int i=gap;ianytype tmp = a[i];

for(j=i;j>=gap&&tmp.compareto(a[j-gap])<0;j-=gap)

a[j]=a[j-gap];

a[j]=tmp;

希爾排序分析:

希爾排序程式設計簡單,但是執行時間的分析則比較麻煩

使用希爾增量排序時希爾排序的最壞情況執行時間為o(n²)

使用hibbard增量的希爾排序的最壞執行時間為o(n二分之三次方)

排序演算法(四) 希爾排序及其優化分析

目錄 1.希爾排序 2.時間複雜度分析 3.空間複雜度分析 希爾排序 shell sort 是插入排序的一種。是針對直接插入排序演算法的改進。該方法又稱縮小增量排序。希爾排序是不穩定的演算法,它滿足穩定演算法的定義。對於相同的兩個數,可能由於分在不同的組中而導致它們的順序發生變化。演算法穩定性 假設...

希爾排序思想分析

這個圖可能一下子看不懂 現在來解釋一下 解釋 第一趟 第1個和第6個比較 排序 第2個和第7個比較,排序 第3個和第8個比較,排序 以此類推直到所有的都排好 第二趟 第1個 第3個 第5個 第7個 第9個 一起比較 排序 第2個 第4個 第6個 第8個 第10個 一起比較 排序 第三趟 都排序 優劣...

演算法 希爾排序及其Python實現

希爾排序思想 有點類似歸併可以分為兩步 1 拆分 2 排序。並且不斷重複這兩個步驟。拆分 gap將資料拆成乙個個小的邏輯小組,並且gap不斷減少。一開始每個組最多只有2個元素,最後慢慢變成整體資料的一半,然後變成整體。而gap從一開始的int len 2 最後變為2.排序 對每個小組進行插入排序。思...