码迷,mamicode.com
首页 > 编程语言 > 详细

算法 之 快速排序法

时间:2016-05-27 16:35:17      阅读:128      评论: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
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!