PHP 插入排序 -- 希爾排序

來源:互聯網
上載者:User

標籤: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 插入排序 -- 希爾排序

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.