PHP中实现归并排序的方法及过程是什么
Admin 2022-08-15 群英技术资讯 934 次浏览
在这篇文章中,我们来学习一下“PHP中实现归并排序的方法及过程是什么”的相关知识,下文有详细的讲解,易于大家学习和理解,有需要的朋友可以借鉴参考,下面就请大家跟着小编的思路一起来学习一下吧。在我们日常的程序开发时候,有时候需要对一个已知的集合按照一定的规则进行排序,其实当数据的规模不太大时或者数据的有序特征比较明显,其实我们可以采用其它的排序算法例如:Bubble Sort, Insertion Sort , Shell Sort 等。 但是前面3中算法的共同特点是,都是从原始的列表里把元素两两取出,然后进行比较,显然冒泡排序和插入排序使用了太多的比较,在数据规模增大时,优势明显下降(主要是以每种算法的复杂度O为参考)。所以这里我们可以尝试用替代法,可以尝试将列表分成更小的子列表然后对他们排序,在排序完更小的子列表后,再将小的子列表合并成一个有序列表,这种方法就是典型的“分治法”,分而治之,逐个克服.(Divide and Conquer).
一般来说,如果一个问题太难以至于无从下手,我们可以尝试将它分成较小的子问题,然后尝试解决这些子问题,最后把这些子问题的结果合并起来。从而解决原始问题。
下图是以一个较短的数组为例来展示整个排序过程:
下面是用PHP code 实现的,以上面的元素为例,着这里主要是借用PHP的2个函数来完成的(array_slice,array_splice).
1 <?php 2 3 4 $input = array(6,3,2,7,1,5,8,4); 5 6 7 function merge_sort($arr) 8 { 9 if(count($arr) <= 1){ 10 return $arr; 11 } 12 13 $left = array_slice($arr,0,(int)(count($arr)/2)); 14 $right = array_slice($arr,(int)(count($arr)/2)); 15 16 $left = merge_sort($left); 17 $right = merge_sort($right); 18 19 $output = merge($left,$right); 20 21 return $output; 22 23 } 24 25 26 function merge($left,$right) 27 { 28 $result = array(); 29 30 while(count($left) >0 && count($right) > 0) 31 { 32 if($left[0] <= $right[0]){ 33 array_push($result,array_shift($left)); 34 }else{ 35 array_push($result,array_shift($right)); 36 } 37 } 38 39 array_splice($result,count($result),0,$left); 40 array_splice($result,count($result),0,$right); 41 42 return $result; 43 44 45 46 } 47 48 49 $output = merge_sort($input); 50 echo "<pre>"; 51 print_r($output); 52 echo "</pre>" 53 ?>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了laravel框架实现后台登录、退出功能,结合实例形式详细分析了Laravel框架后台登录、退出相关的请求发送、验证、session读写与删除等相关操作技巧,需要的朋友可以参考下
浮点型(也叫浮点数float,双精度数double或实数real)可以用以下任一语法定义:<?php$a=1.234;$b=1.2e3;$c=7E-10;?>浮点数的形式表示:LNUM ...
这篇文章主要为大家详细介绍了thinkphp5使用无限极分类,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
php的自动垃圾回收机制是怎样的呢?这个问题我们先这么想,我们都知道php是C语言实现的。你想想如何用C语言实现对一个变量的统计以及释放。C语言是如何实现一个变量,从声明开始到最后没人用了,就把这个变量所占的内存给释放掉(被垃圾回收)。
这篇文章主要介绍了PHP常见加密函数用法,结合实例形式分析了crypt与md5函数进行加密操作相关使用技巧与注意事项,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008