使用php实现的快速排序:
<?php
//快速排序比希尔排序快一个数量级,虽然他们都是O(nlog2n),进过测试100万条随机记录,使用快速排序只需要5秒多
//快速排序相当于织布机的形式,从最右面和参照因子对比
function quickSort(&$arr, $low,$high)
{
//第一个为参照值,小于此值的放在左面,>=此值的放在右面
$temp = $arr[$low];
$i = $low;
$j = $high;
//执行到最后一次递归,因为low>high所以递归就会终止
if ($low < $high) {
while($i < $j) {
//从右面开始找,忽略比因子大的
while($i < $j && $arr[$j] >= $temp) {
$j --;
}
if ($i < $j) {
$arr[$i++] = $arr[$j];
}
//以上的$arr[$i++] = $arr[$j]执行后接下来需要从左面开始找比因子值大的
//忽略<=因子值的数据
while ($i < $j && $arr[$i] <= $temp) {
$i ++;
}
//把比因子值大的放到右面
if ($i < $j) {
$arr[$j --] = $arr[$i];
}
}
$arr[$i] = $temp;
// 后续的递归
quickSort($arr, $low, $i-1);
quickSort($arr, $i+1, $high);
}
}
echo '<pre>';
$start_time = microtime(true);
$arr = range(1, 1000000);
shuffle($arr);
array_unshift($arr, 0);
//print_r($arr);
quickSort($arr, 1,count($arr)-1);
//print_r($arr);
$end_time = microtime(true);
echo $end_time -$start_time;

本文深入探讨了使用PHP实现的快速排序算法,通过实例代码详细解释了其工作原理及优化技巧,展示了快速排序相较于希尔排序的优势,特别是在处理大规模数据集时的效率提升。
1119

被折叠的 条评论
为什么被折叠?



