• php快速排序法


    快速排序是一种常用的排序算法,也是最快的排序算法之一。其基本思想是通过一趟排序将待排序的数据分割成两部分,其中一部分的所有数据都比另一部分的所有数据小,然后再对这两部分分别进行快速排序,递归地重复这个过程,直到整个序列有序。

     

    1. function quickSort($arr) {
    2. $length = count($arr);
    3. if ($length <= 1) {
    4. return $arr;
    5. }
    6. $pivot = $arr[0];
    7. $left = $right = [];
    8. for ($i = 1; $i < $length; $i++) {
    9. if ($arr[$i] < $pivot) {
    10. $left[] = $arr[$i];
    11. } else {
    12. $right[] = $arr[$i];
    13. }
    14. }
    15. return array_merge(quickSort($left), array($pivot), quickSort($right));
    16. }
    17. // 示例用法
    18. $testArr = [8, 3, 1, 6, 4, 7, 2, 5];
    19. $sortedArr = quickSort($testArr);
    20. print_r($sortedArr);
    1. 选择一个基准元素,通常选择序列的第一个元素作为基准元素。
    2. 设定两个指针 left 和 right,分别指向序列的首部和尾部。
    3. 从 right 向 left 扫描,找到第一个小于基准元素的值,将其与基准元素交换。此时,基准元素左侧的元素都小于等于基准元素。
    4. 从 left 向 right 扫描,找到第一个大于基准元素的值,将其与基准元素交换。此时,基准元素右侧的元素都大于基准元素。
    5. 当 left 和 right 相遇时,将基准元素与相遇点交换。
    6. 分别对基准元素左侧和右侧的子序列进行快速排序,递归地重复上述步骤。
  • 相关阅读:
    Meta-Llama-3-8B-Instruct本地推理
    点餐系统-----数据库设计
    如何将力控与PLC之间有线以太网通讯改无线?
    SpringMVC:整合SSM框架
    FDA食品级认证是什么?
    Apache Ant的安装
    ssh基于WEB的农产品销售管理系统
    报告pg_jieba中的bug
    工作需要,JAVAer自学python
    自动化办公更简单了:新版python-office,有哪些更新?
  • 原文地址:https://blog.csdn.net/weixin_39934453/article/details/134399795