首页 > 编程语言 > 详细

算法 之 快速排序法

时间:2016-05-27 16:34:56      阅读:193      评论:0      收藏:0      [点我收藏+]

 

快速排序算法:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行

关键点 : 递归,折半  通常取第一个数为对比

 

时间复杂度 平均 log2(n)*n

    function sort_half($a){
        if(count($a)>1){
            $half = $a[0];
            $left = array();
            $right = array();
            for($i = 1 ; $i < count($a) ; $i++){
                if($a[$i] < $half){
                    $left[] = $a[$i];
                }else{
                    $right[] = $a[$i];
                }
            }
            $right = sort_half($right);
            $left = sort_half($left);
            return array_merge($left,array($half),$right);
        }else{
            return $a;
        }
        
    }
    
    $a = array(3,8,2,5,7,1,6,4);
    $b = sort_half($a);
    print_r($b);
    

 

算法 之 快速排序法

原文:http://www.cnblogs.com/hejun695/p/5534751.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!