排序算法之 - 快速排序

本文介绍了快速排序的基本原理,通过选取基准值将列表分区,然后递归地对左右子列表进行排序,最终达到整个列表排序的目的。快速排序在排序过程中保持了元素的相对顺序,并以递归方式执行,虽然需要递归栈空间,但其平均时间复杂度为O(n log n)。文章还提供了快速排序的执行流程示意图和代码实现。
摘要由CSDN通过智能技术生成

快速排序的第一步是在列表中随机选取一个 基准值,将列表中剩余的其他数与基准值 逐一比较,小于基准值的放在基准值左侧,大于基准值的放在基准值右侧,这样就会形成如下的新列表:

  • [小于基准值的列表] + 基准值 + [大于基准值的列表]

接下来对左侧小于基准值的列表继续执行上述过程,直至最后左侧排序完成

再对右侧大于基准值的列表继续执行上述过程,直至右侧排序完成

  • Notice:在将数字分别放到基准值左右侧时候,总体上并不扰乱数字的顺序,比如5 4 3 2 13为基准值,第一步得到的是[2 1] 3 [5 4]这样的顺序,其中21还是维持它们在初始列表中的顺序,54也是如此

[左侧已完成排序列表]拼接上基准值再拼接上[右侧已完成排序列表],即可得到排序完成的列表。从上面的描述可以看出,,由于需要反复执行快速排序,所以快速排序需要用递归来实现。。以下是执行流程的示意图:

  • 快速排序执行流程及结果:
    快速排序执行流程及结果

PHP实现代码:

<?php

function quickSort($arrayNeedsSort)
{
   
    if (empty($arrayNeedsSort) || count($arrayNeedsSort) <= 1) {
   
        // 基准条件,退出
        return $arrayNeedsSort;
    } else {
   
        // 否则满足递归条件,继续调用自己

        // 选取第一个值作为基准值(随机也是可以的)
        $base = array_shift($arrayNeedsSort);
        $ltArr 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值