算法之-归并排序算法,插入排序算法「建议收藏」

算法之-归并排序算法,插入排序算法

大家好,又见面了,我是全栈君。

一、归并排序法

归并排序是效率还是比較高的算法。当中的分治法是经常使用的一种解决这个问题的方法,如今流行的云计算事实上就是一种分治法的应用。

所谓的分治法,字面解释就是“分而治之”,就是把一个复杂的问题分成两个或很多其它的同样或相似的子问题,直到最后子问题能够简单的直接求解。原问题的解即子问题的解的合并。这个思想在实际工作中的作用很大,特别是处理大数据和做复杂运算的时候。

归并排序的基础是归并操作merge,即将两个有序数组合并为一个有序数组。

归并排序的算法思路为:
第一次扫描数组,将数组中相邻的两个元素merge为有序数组
第二次扫描,将相邻的有序数组再合并为更大的一个有序数组
再进行n次扫描,不断合并数组,直到排序完毕

算法之-归并排序算法,插入排序算法「建议收藏」

当中的归并操作merge的思路是:
设定两个指针,最初位置分别为两个已经排序序列的起始位置
比較两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置
反复步骤3直到某一指针达到序列尾
将还有一序列剩下的全部元素直接拷贝到合并序列尾

好了我们依照上面的思路来用PHP实现归并排序算法:

<?php//归并排序算法//首先定义归并操作merge函数function merge($arr1,$arr2){   $arr3=array();   while(!empty($arr1) && !empty($arr2)){       $arr3[]=$arr1[0]<=$arr2[0]?

array_shift($arr1):array_shift($arr2); } $arr3=array_merge($arr3,$arr1,$arr2); return $arr3;}//归并排序function merge_sort($newarray){ if(count($newarray)<=1) return $newarray; $middle=intval(count($newarray)/2); $arr1=array_slice($newarray, 0,$middle); $arr2=array_slice($newarray, $middle); return merge(merge_sort($arr1), merge_sort($arr2)); }$arr = array(9,8,7,6,5,8,7);print_r( merge_sort($arr));

越来越发现递归算法的重要性,熟练应用递归能够解决非常多实际的问题。

关于递归的理论能够參考http://www.cnsecer.com/4146.html

二、插入排序法

       插入排序(Insertion Sort)的算法描写叙述是一种简单直观的排序算法。它的工作原理是通过构建有序序列。对于未排序数据。在已排序序列中从后向前扫描,找到对应位置并插入。

插入排序在实现上。通常採用in-place排序(即仅仅需用到O(1)的额外空间的排序)。因而在从后向前扫描过程中,须要重复把已排序元素逐步向后挪位,为最新元素提供插入空间。

一般来说,插入排序都採用in-place在数组上实现。详细算法描写叙述例如以下:

  1. 从第一个元素開始,该元素能够觉得已经被排序
  2. 取出下一个元素,在已经排序的元素序列中从后向前扫描
  3. 假设该元素(已排序)大于新元素,将该元素移到下一位置
  4. 反复步骤3,直到找到已排序的元素小于或者等于新元素的位置
  5. 将新元素插入到该位置后
  6. 反复步骤2~5

假设比較操作的代价比交换操作大的话,能够採用二分查找法来降低比較操作的数目。

该算法能够觉得是插入排序的一个变种,称为function insert_sort($arr) { //区分 哪部分是已经排序好的 //哪部分是没有排序的 //找到当中一个须要排序的元素 //这个元素 就是从第二个元素開始,到最后一个元素都是这个须要排序的元素 //利用循环就能够标志出来 //i循环控制 每次须要插入的元素。一旦须要插入的元素控制好了, //间接已经将数组分成了2部分,下标小于当前的(左边的),是排序好的序列 for($i=1, $len=count($arr); $i<$len; $i++) { //获得当前须要比較的元素值。 $tmp = $arr[$i]; //内层循环控制 比較 并 插入 for($j=$i-1;$j>=0;$j--) { //$arr[$i];//须要插入的元素; $arr[$j];//须要比較的元素 if($tmp < $arr[$j]) { //发现插入的元素要小,交换位置 //将后边的元素与前面的元素互换 $arr[$j+1] = $arr[$j]; //将前面的数设置为 当前须要交换的数 $arr[$j] = $tmp; } else { //假设碰到不须要移动的元素 //因为是已经排序好是数组。则前面的就不须要再次比較了。

break; } } } //将这个元素 插入到已经排序好的序列内。 //返回 return $arr;}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115508.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 小程序页面跳转、带参数跳转以及navigator跳转[通俗易懂]

    一、单纯的页面跳转跳转到的页面分tabBar页面和非tabBar页面。url路径可以写相对和绝对路径。1、跳转到非导航页面,用wx.navigateTo方法wx.navigateTo({url:’../person/goldcoin/index’//或者url:’/page/person/goldcoin/index’})2、跳转到tabB…

    2022年4月14日
    201
  • oracle 分页查询 优化_oracle分页查询封装

    oracle 分页查询 优化_oracle分页查询封装对于数据库中表的数据的 Web 显示,如果没有展示顺序的需要,而且因为满足条件的记录如 此之多,就不得不对数据进行分页处理。常常用户并不是对所有数据都感兴趣的,或者大部分情 况下,他们只看前几页。 通常有以下两种分页技术可供选择。 1234567Select * from (Select rownumrn,t.* from table t)Where rn>&minnum and rn或者Sel

    2025年7月18日
    1
  • 适配器简单介绍

    适配器简单介绍适配器的作用如下图:1、这种通信适配器上面装有处理器和存储器(RAM和ROM),硬件地址固化在适配器的ROM中,软件地址(IP地址)在计算机的存储器中。2、适配器在接收和发送各种帧时,不使用计算机的CPU,此时计算机的CPU可以处理其他任务。3、当适配器收到有差错的帧时,就把帧直接丢弃不通知计算机。4、当计算机手收到正确的帧时,就使用中断通知计算机,并交付协议栈中的网络层。5、当计算机发送IP数据…

    2022年5月11日
    42
  • 国内外12个免费域名解析服务网站推荐

    国内外12个免费域名解析服务网站推荐一般域名使用注册商提供的域名解析服务虽然方便,但功能大多有限,特别是目前国内还会针对某些DNS服务器进行屏蔽,造成网站无法解析的情况出现,因此,使用第三方域名解析服务也是中国网站的必要选择,这里就介绍一些常见的免费域名解析服务。域名注册商提供的免费服务Godaddy :不在Godaddy注册域名,也可以使用Godaddy的域名解析服务,使用方法很简单,登录Godaddy网站后,点击“Add…

    2022年6月18日
    306
  • C#之 对象数组

    C#之 对象数组对象数组就是数组里的每个元素都是类的对象,赋值时先定义对象,然后将对象直接赋给数组就行了。万物皆可对象,举个例子:一台电脑。我们就可以把电脑看成一个对象。第一种:常规的写法string[]xxx={}例如我们写一个名字集合的数组:string[]name=newstring[]{“小白”,”小黑”,”小明”};//可以简写为:tring[]nam…

    2022年7月12日
    12
  • MySQL索引的优缺点

    MySQL索引的优缺点一、什么是索引索引用来快速地寻找那些具有特定值的记录,所有MySQL索引都以B-树的形式保存。如果没有索引,执行查询时MySQL必须从第一个记录开始扫描整个表的所有记录,直至找到符合要求的记录。表里面的记录数量越多,这个操作的代价就越高。如果作为搜索条件的列上已经创建了索引,MySQL无需扫描任何记录即可迅速得到目标记录所在的位置。例如有三张表分别是t1、t2、t3,每个表都有字段a1、a2、…

    2022年5月26日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号