標籤:shel 針對 相關 插入排序 直接插入 unshift span src uil
1.希爾排序 -- Shell Insertion Sort
時間複雜度:數學家正在勤勞的探索!
適用條件: 直接插入排序的改進,主要針對移動次數的減少,這取決於"增量隊列"的取值。適用的情況憑個人感覺用吧,我也不知道,反正,我並不認為自己是一個程式員,喜歡憑感覺行事。
1 <?php 2 $arr = [3,4,5,1,11,9,27,27,18,20]; 3 4 5 function shellSort(array &$arr,$dt) 6 { 7 // 跟增量相關,直接排序的改進版,當倒序時,可以極大減少移動的次數。 8 $straightInsertFunc = function(array &$arr,$dt){ 9 $guild = 0; // 監視哨10 array_unshift($arr,$guild);11 $arr = array_values($arr);12 $len = count($arr);13 14 for($i = 1 + $dt;$i < $len;$i += $dt)15 {16 if($arr[$i - $dt] > $arr[$i])17 {18 $arr[0] = $arr[$i];19 $arr[$i] = $arr[$i - $dt];20 for($j = $i - 2 * $dt;$j > 0 && $arr[$j] > $arr[0];$j-=$dt)21 {22 $arr[$j + $dt] = $arr[$j];23 }24 $arr[$j + $dt] = $arr[0];25 }26 }27 array_shift($arr);28 };29 30 if($dt <= 0)31 {32 throw new Exception(‘Param $dt error!‘);33 }34 35 for($i = $dt; $i >= 1; --$i)36 {37 $straightInsertFunc($arr,$dt);38 }39 }40 41 shellSort($arr,3);42 43 echo implode(‘,‘,$arr);
運行結果:
PHP 插入排序 -- 希爾排序