首页 >后端开发 >php教程 > 正文

php的快速排序的代码

原创2018-07-06 11:00:240812
这篇文章主要介绍了关于php的快速排序的代码,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

一、原理介绍

其实说来很简单
一个数组 [6, 1, 2, 7, 9, 3, 4, 5, 10, 8]
a、找第一个6(任意都行)
b、把比6小的、比6大的分开,各成1个数组
c、b操作得到两个数组,再重复执行ab操作,最终合并数组

二、上代码

/**
 * 快速排序
 */
function quick_sort($arr)
{
    $length = count($arr);
    if ($length <= 1) {
        return $arr;
    }
    $left = $right = [];
    for ($i = 1; $i < $length; $i++) {
        if ($arr[$i] < $arr[0]) {
            $left[] = $arr[$i];
        } else {
            $right[] = $arr[$i];
        }

    }
    //递归调用
    $left = quick_sort($left);
    $right = quick_sort($right);
    return array_merge($left, [$arr[0]], $right);
}
$arr_data = [6, 1, 2, 7, 9, 3, 4, 5, 10, 8];
print_r(quick_sort($arr_data));

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

PHP变量之作用域、global、static等关键字

PHP中常用的header头部定义

以上就是php的快速排序的代码的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

  • 相关标签:php
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 专题推荐

    作者信息
    推荐视频教程
  • javascript初级视频教程javascript初级视频教程
  • jquery 基础视频教程jquery 基础视频教程
  • 视频教程分类