zoukankan      html  css  js  c++  java
  • 算法 之 快速排序法

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

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

    时间复杂度 平均 n*logn

        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);
        
  • 相关阅读:
    看书笔记《python基础》__1
    MQTT
    杂记
    类型转化
    soc
    时钟同步
    设置地址
    清理日志
    pandas_matplot_seaborn
    Qt_Quick开发实战精解_4
  • 原文地址:https://www.cnblogs.com/hejun695/p/5534751.html
Copyright © 2011-2022 走看看