新大榭论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

《新大榭》- 创大榭地方网络社区先锋品牌 新大榭始终专注于地方网络社区平台的建设 关于我们- [大记事]- 留言建议- [新手报道]

发布 .新大榭软件管家(Excel版) V5.9版 财务/仓库/生产/销售/采购/行政/人事/校园 .公告 - 客户 - 打赏 - 职场 - Excel - Python.

新大榭镜像-音乐-法律-图书-高中课堂-实验 广告是为了能更好的发展 [欢迎商家支持本站互利共赢] 广告位招租.首页黄金广告位等您来!联系 13566035181

查看: 1785|回复: 0

[PHP] 7967 - PHP数组排序算法:合并算法

[复制链接]
发表于 2021-10-27 10:47:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转新大榭论坛!

您需要 登录 才可以下载或查看,没有账号?注册

x
  1. <?php

  2.         //PHP数组排序算法:合并算法

  3.         //二路归并
  4.         $arr1 = array(1,3,5);
  5.         $arr2 = array(2,4,6);

  6.         //取出一个空数组用于归并空间
  7.         $arr3 = array();
  8.         while(count($arr1) && count($arr2)){
  9.                 //只要$arr1和$arr2里面还有元素,就进行循环
  10.                 //取出每个数组的第一个元素:进行比较
  11.                 $arr3[] = $arr1[0]  < $arr2[0] ? array_shift($arr1) : array_shift($arr2);
  12.         }

  13.         //合并结果
  14.         //print_r(array_merge($arr3,$arr1,$arr2));



  15.         $arr = array(4,7,2,1,5,9,3);

  16.         //归并排序函数
  17.         function merge_sort($arr){
  18.                 //递归出口
  19.                 $len = count($arr);
  20.                 if($len <= 1) return $arr;

  21.                 //拆分
  22.                 $middle = floor($len / 2);
  23.                 $left = array_slice($arr,0,$middle);
  24.                 $right = array_slice($arr,$middle);

  25.                 //递归点:$left和$right都没有排好序:而且可能是多个元素的数组
  26.                 $left = merge_sort($left);
  27.                 $right = merge_sort($right);

  28.                 //假设左边和右边都已经排好序:二路归并
  29.                 $m = array();
  30.                 while(count($left) && count($right)){
  31.                         //只要$arr1和$arr2里面还有元素,就进行循环
  32.                         //取出每个数组的第一个元素:进行比较
  33.                         $m[] = $left[0]  < $right[0] ? array_shift($left) : array_shift($right);
  34.                 }
  35.                 //返回结果
  36.                 return array_merge($m,$left,$right);
  37.        
  38.         }

  39.         print_r(merge_sort($arr));
  40. ?>
复制代码
新大榭Python学习社区培训、Excel业务指导、办公软件定制、网站建设;新大榭探索实验室欢迎您!http://lab.daxie.net.cn/
Q群推荐 大榭本地求职招聘QQ群,欢迎转发分享本地招聘信息资讯! 官方招聘1群(已满);官方招聘2群:315816937 *
您需要登录后才可以回帖 登录 | 注册

本版积分规则

文字版|小黑屋|新大榭 ( 浙ICP备16018253号-1 )|点击这里给站长发消息|

GMT+8, 2025-12-6 07:26 , Processed in 0.079094 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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