PHP中实现归并排序的方法及过程是什么
Admin 2022-08-15 群英技术资讯 1186 次浏览
在这篇文章中,我们来学习一下“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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
php怎样现实上传和下载文件?很多网站都会提供文件的上传与下载功能,那么这一操作是如何实现的?下面是PHP实现对文件上传与下载操作的代码,有需要的朋友可做参考。
php底层运行机制与原理是什么?很多人可能没有深入了解过这个问题,这篇文章就带大家了解一下php底层做些什么工作以及原理是什么?感兴趣的朋友就继续往下看吧。
可以基于swoole和redis队列来完成一个消息通知推送功能,利用swoole开启常驻进程,需要几个按自己的情况来定,swoole进程数最好是和服务器cpu核数相等,利用swoole启动的常驻进程不断的去探测redis队列里面的值。
在本篇文章里小编给大家整理了关于php利用ZipArchive类实现文件压缩与解压实例代码内容,需要的朋友们学习下。
在laravel中,dd()属于laravel辅助函数;dd函数用于输出给定的值并结束脚本运行,可以打印laravel中的所有变量,语法为“dd($value1,$value2...)”。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
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核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008