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

    php实现快速排序的算法思想与代码

    不言不言2018-08-14 17:15:45原创611

    本篇文章给大家带来的内容是关于php实现快速排序的算法思想与代码,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    核心思想:按大小一分为二,分别递归排序,瞻前顾后(分割 函数)。

    338351600-5b6c51cfcd98f_articlex.png

    php代码如下:

    <?php
    function    quickSort($arr){
        $resultArr=qSort($arr,0,count($arr)-1);
        return  $resultArr;
    }
    function    qSort($arr,$low,$high){
       if($low<$high){
           //算出枢轴值
           $partRes=partition($arr,$low,$high);
           $arr=$partRes["resultArr"];
           
           $arr=qSort($arr,$low,$partRes["pivot"]-1);//对低子表递归排序
           $arr=qSort($arr,$partRes["pivot"]+1,$high);//对高子表递归排序
       }
       return   $arr;
    }
    function    partition($arr,$low,$high){
        $pivotkey=$arr[$low];   //用子表的第一个记录作枢纽记录
        while ($low<$high){     //从表的两端交替向中间扫描
            while ($low<$high&&$arr[$high]>=$pivotkey){
                $high--;
            }
            $arr=swap($arr,$low,$high);//将比枢轴记录小的记录交换到低端
            while ($low<$high&&$arr[$low]<=$pivotkey){
                $low++;
            }
            $arr=swap($arr,$low,$high);//将比枢轴记录大的记录交换到高端
        }
        return  array("pivot"=>$low,"resultArr"=>$arr);//返回枢轴所在位置
    }
    function    swap($arr,$index1,$index2){
        $pivotkey=$arr[$index1];
        $arr[$index1]=$arr[$index2];
        $arr[$index2]=$pivotkey;
        return  $arr;
    }
    $arr=array(9,1,3,2,6,7,4,8);
    $resultArr=quickSort($arr);
    echo implode(',',$resultArr);

    相关文章推荐:

    PHP快速排序小例子 php快速排序实现方法

    快速排序PHP实现 php 快速排序法 php 快速排序的思路 快速排序算

    以上就是php实现快速排序的算法思想与代码的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:php实现快速排序
    上一篇:PHP环境如何进一步加强安全防范?php环境安全加强的方法介绍 下一篇:PHP如何将不是UTF8的字符过滤掉(代码)
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• PHP写入XML文件事字表数据只读一条数据,什么原因 • 【PHP】界别include(),require(),include_once(),require_once() • js 弹窗出现乱码了解决方案 • 关于appserv的有关问题 • 本人初学者刚接触php,安装安装了XAMPP后,出现了些有关问题,求大神帮帮忙
    1/1

    PHP中文网