PHP 快速排序

來源:互聯網
上載者:User

標籤:返回   快速排序   lod   return   function   方法   sort   unshift   com   

1.快速排序 -- Quick Sort。

2.時間複雜度:T(n) = k* n *ln(n) (k常數因子)

3.適用條件:目前認為最好的內部排序方法。

 1 <?php 2 $arr = [3,4,5,1,11,9,27,27,18,20]; 3  4 function quickSort(array &$arr,$low,$high) 5 { 6     $partQuickSort = function(array &$arr,$low,$high){ 7         $arr[0] = $arr[$low]; 8  9         while($low < $high)10         {11             while($low < $high && $arr[$high] >= $arr[0])12             {13                 --$high;14             }15             $arr[$low] = $arr[$high];16 17             while($low < $high && $arr[$low] <= $arr[0])18             {19                 ++$low;20             }21             $arr[$high] = $arr[$low];22         }23         $arr[$low] = $arr[0];24 25         return $low;    // 返回樞軸位置26     };27 28     if($low < $high)29     {30         $pivot = $partQuickSort($arr,$low,$high);31         quickSort($arr,1,$pivot-1);32         quickSort($arr,$pivot+1,$high);33     }34 }35 array_unshift($arr,0);36 quickSort($arr,1,count($arr)-1);37 array_shift($arr);38 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.