时间:2021-07-01 10:21:17 帮助过:4人阅读
其实说来很简单
一个数组 [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的快速排序的代码的详细内容,更多请关注Gxl网其它相关文章!