《PHP實戰:PHP 快速排序算法詳解》要點:
本文介紹了PHP實戰:PHP 快速排序算法詳解,希望對您有用。如果有疑問,可以聯系我們。
PHP學習觀點
PHP學習這里借用百度百科的一張圖來,異常形象:
PHP進修
PHP學習快速排序算法是對冒泡算法的一個優化.他的思想是先對數組進行分割, 把年夜的元素數值放到一個臨時數組里,把小的元素數值放到另一個臨時數組里(這個分割的點可以是數組中的任意一個元素值,一般用第一個元素,即$array[0]),然后繼續把這兩個臨時數組重復上面拆分,最后把小的數組元素和年夜的數組元素合并起來.這里用到了遞歸的思想.
PHP進修PHP實現
PHP學習function quickSort($array)
{
??? if(!isset($array[1]))
??????? return $array;
??? $mid = $array[0]; //獲取一個用于朋分的關鍵字,一般是首個元素
??? $leftArray = array();
??? $rightArray = array();
PHP學習??? foreach($array as $v)
??? {
??????? if($v > $mid)
??????????? $rightArray[] = $v;? //把比$mid年夜的數放到一個數組里
??????? if($v < $mid)
??????????? $leftArray[] = $v;?? //把比$mid小的數放到另一個數組里
??? }
PHP學習??? $leftArray = quickSort($leftArray); //把比擬小的數組再一次進行分割
??? $leftArray[] = $mid;??????? //把分割的元素加到小的數組后面,不能忘了它哦
PHP學習??? $rightArray = quickSort($rightArray);? //把比擬大的數組再一次進行分割
??? return array_merge($leftArray,$rightArray);? //組合兩個結果
}
PHP學習與冒泡算法對照
PHP學習這里我與之前寫的冒泡算法實現的排序做了個對照,可以看出這個算法比冒泡算法的效率要高很多.
PHP學習require('./maopao.php');? //這里引用的是我之前寫的冒泡算法排序
$t1 = microtime(true);
maoPao($a);?? //冒泡
$t2 = microtime(true);
echo (($t2-$t1)*1000).'ms';
PHP學習運行成果:
《PHP實戰:PHP 快速排序算法詳解》是否對您有啟發,歡迎查看更多與《PHP實戰:PHP 快速排序算法詳解》相關教程,學精學透。維易PHP學院為您提供精彩教程。