职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 365|回复: 0

php递归快速排序示例

[复制链接]
无处不在 发表于 2017-3-27 15:40 | 显示全部楼层 |阅读模式
  1. <?php

  2.         //php北归快速排序示例
  3.         $arr = array(16,2,9,996,74,233,92,55,1,0);


  4.         function quick_sort($arr){

  5.                 if(!is_array($arr)) return false;

  6.                 //递归出口:数组长度为1就直接返回数组
  7.                 $length = count($arr);
  8.                 if($length <= 1) return $arr;

  9.                 //数组元素有多个
  10.                 $left = $right = array();

  11.                 //使用for循环进行遍历,把第一个元素当做比较的对象
  12.                 for($i = 1;$i < $length;$i++){
  13.                         //判断当前元素值的大小
  14.                         if($arr[$i] < $arr[0]){
  15.                                 //当前元素小于标准元素,放到左边数组
  16.                                 $left[] = $arr[$i];
  17.                         }else{
  18.                                 $right[] = $arr[$i];
  19.                         }
  20.                 }

  21.                 //递归调用
  22.                 $left = quick_sort($left);
  23.                 $right = quick_sort($right);

  24.                 //将所有的结果合并
  25.                 return array_merge($left,array($arr[0]),$right);
  26.         }

  27.         echo '<pre>';
  28.         //调用
  29.         print_r(quick_sort($arr));
复制代码


您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-4-26 14:54 , Processed in 0.120731 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表