PHP实现快速排序

快速排序也是基础排序之一,是每个程序员应该掌握的算法。

public function run($args)
{
    @set_time_limit(0);
    @ini_set('memory_limit', '2048M');

    $obj_arr = array(5,4,2,3,6,2,3,7,1,5,6,8,9,4,3,13,22,42,14,15);
    $obj_arr = $this->sortArr($obj_arr);
    var_export($obj_arr);
}
public function sortArr($arr){
    $right_arr = array();
    $left_arr = array();
    $length = count($arr);
    if($length <= 1){//只有一个元素的时候终止
        return $arr;
    }
    $pareNum = $arr[0];
    for($i=1;$i<$length;$i++){//1开始,第一个元素已经有序了
        if($arr[$i] > $pareNum){
            $right_arr[] = $arr[$i];
        }else{
            $left_arr[] = $arr[$i];
        }
    }
    $left_arr = $this->sortArr($left_arr);
    $right_arr = $this->sortArr($right_arr);
    return array_merge($left_arr,array($pareNum),$right_arr);//把中间元素加上
}
输出:

array (
  0 => 1,
  1 => 2,
  2 => 2,
  3 => 3,
  4 => 3,
  5 => 3,
  6 => 4,
  7 => 4,
  8 => 5,
  9 => 5,
  10 => 6,
  11 => 6,
  12 => 7,
  13 => 8,
  14 => 9,
  15 => 13,
  16 => 14,
  17 => 15,
  18 => 22,
  19 => 42,
)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值