天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP 遞歸效率分析

而且是差了3倍的效率。所以,php中的遞歸一定要小心的對待。
最近寫了一個快速排序的算法,發現php中的遞歸效率不能一刀切,在各種不同的服務器中,可能會表現不一樣。
復制代碼 代碼如下:
function qsort(&$arr)
{
_quick_sort($arr, 0, 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);
}
}
}

下面是測試速度的代碼:
復制代碼 代碼如下:
function qsort_test1()
{
$arr = range(1, 1000);
shuffle($arr);
$arr2 = $arr;
$t1 = microtime(true);
quick_sort($arr2);
$t2 = microtime(true) - $t1;
echo "非遞歸調用的花費:" . $t2 . "/n";
$arr1 = $arr;
$t1 = microtime(true);
qsort($arr1);
$t2 = microtime(true) - $t1;
echo "遞歸調用的花費:" . $t2 . "/n";


在我的IIS 服務器上(CGI)模式,我的測試結果是:
非遞歸調用的花費:0.036401009559631
遞歸調用的花費:0.053439617156982
在我的Apache 服務器上,我的測試結果是:
非遞歸調用的花費:0.022789001464844
遞歸調用的花費:0.014809131622314
結果完全相反,而php的版本是一樣的。
看來對遞歸的效率要具體問題具體分析了。

php技術PHP 遞歸效率分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 精品四虎国产在免费观看 | 18禁止观看免费私人影院 | 不良网站进入窗口软件下载免费 | 99久久精品免费看国产一区二区 | 亚洲 欧美 日韩 国产 视频 | 激情内射亚洲一区二区三区爱妻 | 亚洲精品伊人久久久久 | 苍老师刺激的120分钟 | 久久AV国产麻豆HD真实乱 | 入禽太深免费高清在线观看5 | 精品国产福利一区二区在线 | 女教师公车痴汉在线播放 | 国产亚洲精品精品国产亚洲综合 | 色噜噜色啪在线视频 | 色cccwww| 在线视频a| 古代荡女丫鬟高H辣文纯肉 姑娘视频日本在线播放 | 含羞草最新版本 | 国产午夜在线观看视频播放 | 久久免费精品国产72精品剧情 | 伊人久久大线蕉香港三级 | 亚洲国产精品特色大片观看 | 东京热百度影音 | 99久久免费看国产精品 | 色多多污污下载 | 亚洲蜜桃AV永久无码精品放毛片 | 1000部做羞羞事禁片免费视频网站 | 国产高清视频青青青在线 | 小鸟酱喷水 | 美女张开腿让男生桶动态图 | 任你躁精品一区二区三区 | 18禁在线无遮挡羞羞漫画 | 欧美亚洲日韩在线在线影院 | 国产午夜精品理论片免费观看 | 国精产品一区二区三区有限公司 | a视频在线观看 | 国产精品99久久久久久人韩国 | 亚洲乱亚洲乱妇13p 亚洲乱色视频在线观看 | 肉动漫无码无删减在线观看 | 毛片免费观看的视频在线 | 调教玩弄奶头乳夹开乳震动器 |