PHP中实现归并排序的方法及过程是什么
Admin 2022-08-15 群英技术资讯 1284 次浏览
在这篇文章中,我们来学习一下“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服务容器及使用,以及服务绑定与解析都有详细的介绍,感兴趣的朋友就继续往下看吧。
基于PHP怎样写一个简单的投票系统?下文的讲解详细,步骤过程清晰,对大家进一步学习和理解相关知识有一定的帮助。有这方面学习需要的朋友就继续往下看吧!
php中get和post的不同:1、GET生成一个TCP数据包,POST生成两个TCP数据包。2、GET请求只能进行url编码,而POST支持多种编码方式。3、当浏览器退回时,GET是无害的,POST将再次提交请求。
冒泡排序、选择排序、插入排序、快速排序这四种PHP中经典的排序方式是经常能用到的,所以学习PHP一定要掌握这些。
Laravel 是一个流行的开源 PHP 框架,以其强大的安全性和简单而复杂的编码架构而闻名。本篇文章就给大家带来了关于Laravel 性能优化的 18 个必备知识,希望对需要的朋友有所帮助!
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
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