快速排序写法和思路



 /**
 * 快速排序
 * @param $arr
 * @return array
 */
$arr自定义一个数组,先得到该数组的长度,定义一个left数组 ,right数组,注意这必须判断数组长度,如果小于1就让他直接返回,不然引用会报错,外层一个for循环
是判断数组长度,用$arr【0】第一个数字跟第二个数字对比,如果大于第二个数字,把它放在left这个数组里面,如果小于放在right里面,循环一轮之后会得到left和right
这两个数组,再用这个数组调用自己定义的goSort方法进行循环,之后拼接数组。注意:$arr[0]不是数组,需要转换为数组。
 function goSort($arr){
    $len=count($arr);
    $left=array();
    $right=array();
    if($len<=1){
        return $arr;
    }
    for($i=1;$i<$len;$i++){
        if($arr[$i]<$arr[0]){
            $left[]=$arr[$i];
        }else{
            $right[]=$arr[$i];
        }
    }
    $left=goSort($left);
//    return $left;
    $right=goSort($right);
    return array_merge($left,array($arr[0]),$right);

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值