手机
当前位置:查字典教程网 >脚本专栏 >python >php使用递归与迭代实现快速排序示例
php使用递归与迭代实现快速排序示例
摘要:复制代码代码如下:/***递归法实现的快速排序*@param$seq*@returnarray*/functionquicksort($se...

复制代码 代码如下:

/**

* 递归法实现的快速排序

* @param $seq

* @return array

*/

function quicksort($seq)

{

if (count($seq) > 1) {

$k = $seq[0];

$x = array();

$y = array();

$_size = count($seq); //do not use count($seq) in loop for.

for ($i = 1; $i < $_size; $i++) {

if ($seq[$i] <= $k) {

$x[] = $seq[$i];

} else {

$y[] = $seq[$i];

}

}

$x = quicksort($x);

$y = quicksort($y);

return array_merge($x, array($k), $y);

} else {

return $seq;

}

}

/**用迭代实现

* @param $seq

* @return array

*/

function quicksortX(&$seq)

{

$stack = array($seq);

$sort = array();

while ($stack) {

$arr = array_pop($stack);

if(count($arr) <= 1){

if (count($arr) == 1) {

$sort[] = &$arr[0];

}

continue;

}

$k = $arr[0];

$x = array();

$y = array();

$_size = count($arr);

for ($i = 1; $i < $_size; $i++) {

if ($arr[$i] <= $k) {

$x[] = &$arr[$i];

} else {

$y[] = &$arr[$i];

}

}

!empty($y) && array_push($stack, $y);

array_push($stack, array($arr[0]));

!empty($x) && array_push($stack, $x);

}

return $sort;

}

//$testArr = array(5545, 5, 6, 7675, 100, 9, 233, 566, 789, 456, 23, 55, 7, 4, 343, 564, 5, 45657, 8, 998, 9, 34, 34, 55, 6, 5, 6433, 67, 6, 6766, 4, 2, 42, 25634, 34343, 3, 3, 454, 4, 65, 6678, 57, 5455);

for($i=0;$i<20;$i++){

$testArr[]=mt_rand(0,10000);

}

//var_dump($testArr);

echo count($testArr).'<br>';

$start=microtime();

echo count(quicksort($testArr)).'<br>';

echo microtime()-$start.'<br>';

var_dump(quicksort($testArr));

echo '------------------------------------------------------------------------<br>';

echo count($testArr).'<br>';

$start=microtime();

echo count(quicksortX($testArr)).'<br>';

echo microtime()-$start.'<br>';

var_dump(quicksortX($testArr));

【php使用递归与迭代实现快速排序示例】相关文章:

python函数返回多个值的示例方法

使用python将mdb数据库文件导入postgresql数据库示例

python实现百度关键词排名查询

python 实现文件的递归拷贝实现代码

python实现ftp客户端示例分享

python迭代器的使用方法实例

python实现巡检系统(solaris)示例

python实现socket客户端和服务端简单示例

python中使用OpenCV进行人脸检测的例子

python 实现插入排序算法

精品推荐
分类导航