菜单

PHP排序算法之直接插入排序(Straight Insertion Sort)实例剖判

2019年6月27日 - 金沙编程资讯

企望本文所述对我们PHP程序设计有所支持。

直接插入排序是由两层嵌套循环组成的。外层循环标记并操纵待比较的数值。内层循环为待比较数值鲜明其最终地点。间接插入排序是将待相比较的数值与它的前二个数值举行相比,所以外层循环是从第叁个数值起首的。当前一数值比待比较数值大的图景下继续循环相比较,直到找到比待相比数值小的并将待相比数值置入其后一职分,结束该次循环。

在线动画演示插入/选拔/冒泡/归并/Hill/快捷排序算法进度工具:

直接插入排序算法的小时复杂度为 O(n^2)。

扑克牌是大家大概各类人都玩过的游乐。日常大家开头的时候一般都是壹位发放营业证件本,别的人都以一派摸牌,一边理牌,假诺你摸上的首先张牌是
5,第二张牌是 3,自然而然的大家把 3 插到 5 的前方;第三张牌是 4,查到
3 和 5 的中游;第四张牌是 6,放到 5 的末端;第五张牌是 2,插到 3
的前边;……。最后当大家摸完全体的牌时,手上的牌都以从小到大(点数)排好序的。

大旨思量:

直接插入排序是安静排序。

正文实例呈报了PHP排序算法之直接插入排序(Straight Insertion
Sort)。分享给大家供大家参考,具体如下:

首先趟比较前七个数,然后把第二个数按大小插入到有序表中;
第二趟把第七个数据与前多少个数从后迈入扫描,把第八个数按大小插入到有序表中;依次实行下去,举办了(n-1)趟扫描今后就完了了整套排序进程。

插入排序的主干措施是:每步将八个待排序的笔录按其重大字的分寸插到方今已经排序的队列中的适当地方,直到整个记下插入完成截止。

你或然感兴趣的稿子:

直接插入排序的中坚思量是 :
每一回从冬辰表中取出第多个因素,把它插入到有序表的熨帖岗位,使有序表还是始终不渝。

在此处大家照例选取《高调数据结构》里面包车型客车五个例子:

咱俩来看那么些顺序:

array(9) {
 [0]=>
 int(1)
 [1]=>
 int(2)
 [2]=>
 int(3)
 [3]=>
 int(4)
 [4]=>
 int(5)
 [5]=>
 int(6)
 [6]=>
 int(7)
 [7]=>
 int(8)
 [8]=>
 int(9)
}

5               3           // 将 3
插入唯有贰个要素 5 的静止表中
3 5             4           // 将 4 插入有多个因素 3 5 的不改变表中
3 4 5           6           // 将 6 插入有五个要素 3 4 5 的平稳表中
3 4 5 6         2           // 将 2 插入有多个因素 3 4 5 6 的稳步表中
2 3 4 5 6

算法引进:

运营结果:

算法达成:

更多关于PHP相关内容感兴趣的读者可查阅本站专项论题:《php排序算法总计》、《PHP数据结构与算法教程》、《php程序设计算法总括》、《php字符串(string)用法计算》、《PHP数组(Array)操作本领大全》、《PHP常用遍历算法与才干总结》及《PHP数学生运动算技术总括》

<?php
//直接插入排序
function swap(array &$arr,$a,$b){
  $temp = $arr[$a];
  $arr[$a] = $arr[$b];
  $arr[$b] = $temp;
}
function InsertSort(array &$arr){
  $count = count($arr);
  //数组中第一个元素作为一个已经存在的有序表
  for($i = 1;$i < $count;$i ++){
    $temp = $arr[$i];   //设置哨兵
    for($j = $i - 1;$j >= 0 && $arr[$j] > $temp;$j --){
      $arr[$j + 1] = $arr[$j];    //记录后移
    }
    $arr[$j + 1] = $temp;   //插入到正确的位置
  }
}
$arr = array(9,1,5,8,3,7,4,6,2);
InsertSort($arr);
var_dump($arr);

本文参考自《高调数据结构》,在此仅作记录,方便今后翻看,大神勿喷!

PS:这里再为大家推荐一款有关排序的示范工具供大家仿效:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图