PHP 递归效率分析
前端之家收集整理的这篇文章主要介绍了
PHP 递归效率分析,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
而且是差了3倍的效率。所以,PHP中的递归一定要小心的对待。
最近写了一个快速排序的算法,发现PHP中的递归效率不能一刀切,在各种不同的服务器中,可能会表现不一样。
<div class="codetitle"><a style="CURSOR: pointer" data="11059" class="copybut" id="copybut11059" onclick="doCopy('code11059')"> 代码如下:
<div class="codebody" id="code11059">
function qsort(&$arr)
{
_quick_sort($arr,count($arr) - 1);
} /*
采用递归算法的
快速排序。
@param array $arr 要排序的数组
@param int $low 最低的排序子段
@param int $high 最高的排序字段
*/
function _quick_sort(&$arr,$low,$high)
{
$low_data = $arr[$low];
$prev_low = $low;
$prev_high = $high;
while ($low < $high)
{
while ($arr[$high] >= $low_data && $low < $high) {
$high--;
}
if ($low < $high) {
$arr[$low] = $arr[$high];
$low++;
}
while ($arr[$low] <= $low_data && $low < $high) {
$low++;
}
if ($low < $high) {
$arr[$high] = $arr[$low];
$high--;
}
}
$arr[$low] = $low_data;
if ($prev_low < $low) {
_quick_sort($arr,$prev_low,$low);
}
if ($low + 1 < $prev_high) {
_quick_sort($arr,$low + 1,$prev_high);
}
} function quick_sort(&$arr)
{
$stack = array();
array_push($stack,0);
array_push($stack,count($arr) -1);
while (!empty($stack)) {
$high = array_pop($stack);
$low = array_pop($stack);
$low_data = $arr[$low];
$prev_low = $low;
$prev_high = $high;
while ($low < $high)
{
while ($arr[$high] >= $low_data && $low < $high) {
$high--;
}
if ($low < $high) {
$arr[$low] = $arr[$high];
$low++;
}
while ($arr[$low] <= $low_data && $low < $high) {
$low++;
}
if ($low < $high) {
$arr[$high] = $arr[$low];
$high--;
}
}
$arr[$low] = $low_data;
if ($prev_low < $low) {
array_push($stack,$prev_low);
array_push($stack,$low);
}
if ($low + 1 < $prev_high) {
array_push($stack,$low + 1);
array_push($stack,$prev_high);
}
}
}