這篇文章主要介紹了php快速排序原理與實現方法,結合實例形式分析了php快速排序的演算法原理與具體實現技巧,需要的朋友可以參考下
具體如下:
<?php $n = array('13','14','55','10','54','2','79','106','89','90','22','60','111','77777','-110','-10','123'); function partition($n,$left,$right) { global $n; $pivot = $n[$left]; $lo=$left; $hi=$right+1; while($lo+1!=$hi) { if($n[$lo+1]<$pivot) $lo++; else if($n[$hi-1]>$pivot) $hi--; else{ $t=$n[$lo+1]; $n[$lo+1]=$n[$hi-1]; $n[$hi-1]=$t; $lo++; $hi--; } } $n[$left]=$n[$lo]; $n[$lo]=$pivot; return $lo; } function quicksort($n,$left,$right) { global $n; $dp = 0; if ($left<$right) { $dp=partition($n,$left,$right); quicksort($n,$left,$dp-1); quicksort($n,$dp+1,$right); } } quicksort($n,0,sizeof($n)-1); print_r($n); ?>
快速排序是對冒泡排序的一種改進。它的基本想法是:透過一躺排序將要排序的資料分割成獨立的兩部分,其中一部分的所有資料都比另外一不部分的所有資料都要小,然後再按次方法對這兩部分資料分別進行快速排序,整個排序過程可以遞歸進行,以此達到整個資料變成有序序列。
假設要排序的陣列是A[1]…A[N],首先任意選取一個資料(通常選用第一個資料)作為關鍵數據,然後將所有比它小的數都放到它前面,所有比它大的數都放到它後面,這個過程稱為一躺快速排序。一躺快速排序的演算法是:
1)、設定兩個變數I、J,排序開始的時候I:=1,J:=N;
2)、以第一個陣列元素作為關鍵數據,賦值給X,即X:=A[1];
3)、從J開始向前搜索,即從後開始向前搜索(J:=J-1),找到第一個小於X的值,兩者交換;
4)、從I開始向後搜索,即由前開始向後搜索(I:=I 1),找到第一個大於X的值,兩者交換;
5)、重複第3、4步,直到I=J;
快速排序就是遞歸呼叫此過程-在以49為中點分割這個資料序列,分別對前面一部分和後面一部分進行類似的快速排序,從而完成全部資料序列的快速排序,最後把此資料序列變成一個有序的序列
總結:以上就是本篇的全部內容,希望能對大家的學習有所幫助。
相關推薦:
以上是php快速排序原理與實作方法及實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!