• 技术文章 >后端开发 >php教程

    PHP 快速排序算法详解_PHP

    2016-05-31 19:28:05原创364
    概念

    这里借用百度百科的一张图来,非常形象:

    快速排序算法是对冒泡算法的一个优化。他的思想是先对数组进行分割, 把大的元素数值放到一个临时数组里,把小的元素数值放到另一个临时数组里(这个分割的点可以是数组中的任意一个元素值,一般用第一个元素,即$array[0]),然后继续把这两个临时数组重复上面拆分,最后把小的数组元素和大的数组元素合并起来。这里用到了递归的思想。

    PHP实现

    代码如下:


    /*
    快速排序
    */

    function quickSort($array)
    {
    if(!isset($array[1]))
    return $array;
    $mid = $array[0]; //获取一个用于分割的关键字,一般是首个元素
    $leftArray = array();
    $rightArray = array();

    foreach($array as $v)
    {
    if($v > $mid)
    $rightArray[] = $v; //把比$mid大的数放到一个数组里
    if($v < $mid)
    $leftArray[] = $v; //把比$mid小的数放到另一个数组里
    }

    $leftArray = quickSort($leftArray); //把比较小的数组再一次进行分割
    $leftArray[] = $mid; //把分割的元素加到小的数组后面,不能忘了它哦

    $rightArray = quickSort($rightArray); //把比较大的数组再一次进行分割
    return array_merge($leftArray,$rightArray); //组合两个结果
    }

    与冒泡算法对比

    这里我与之前写的冒泡算法实现的排序做了个对比,可以看出这个算法比冒泡算法的效率要高很多。

    代码如下:


    $a = array_rand(range(1,3000), 1500); //甚至在冒泡算法超过1600个元素的时候会出现内存不足的提示,但这里为了测出两个之间的差别大小, 就设置成了1500,保证冒泡算法也能执行完毕。
    shuffle($a); //获取已经打乱了顺序的数组
    $t1 = microtime(true);
    quickSort($a); //快速排序
    $t2 = microtime(true);
    echo (($t2-$t1)*1000).'ms
    ';

    require('./maopao.php'); //这里引用的是我之前写的冒泡算法排序
    $t1 = microtime(true);
    maoPao($a); //冒泡
    $t2 = microtime(true);
    echo (($t2-$t1)*1000).'ms';

    运行结果:

    代码如下:


    12.10880279541ms
    772.64094352722ms

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:php 快速排序算法
    上一篇:PHP中的Streams详细介绍_PHP 下一篇:php实现压缩多个CSS与JS文件的方法_PHP
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• PHP是如何存储变量的?zval结构体你了解吗?• ThinkPHP2.0读取MSSQL提示Incorrect syntax near the keyword 'AS'的解决方法_php实例• php实现水仙花数的4个示例分享_php实例• PHP根据IP地址获取所在城市具体实现_php实例• php 三维饼图的实现代码_php实例
    1/1

    PHP中文网