各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案

Str Tom,为分享PHP技术和解决方案,贡献一份自己的力量!
收藏本站(不迷路),每天更新好文章!
当前位置:首页 > CMS教程 > PHP

PHP排序算法系列之插入排序的详解

管理员 2023-09-05
PHP
81

PHP排序算法系列之插入排序的详解

内容导读

收集整理的这篇技术教程文章主要介绍了PHP排序算法系列之插入排序的详解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1829字,纯文字阅读大概需要3分钟

内容图文

这篇文章主要为大家详细介绍了PHP排序算法系列之插入排序的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

插入排序

有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候就要用到一种新的排序方法——插入排序法,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。

原理

直接插入排序(Insertion Sort)的基本思想是:每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子序列中的适当位置,直到全部记录插入完成为止。
设数组为a[0…n-1]。

1.初始时,a[0]自成1个有序区,无序区为a[1..n-1]。令i=1
2.将a[i]并入当前的有序区a[0…i-1]中形成a[0…i]的有序区间。
3.i++并重复第二步直到i==n-1。排序完成。

PHP代码实现

function insertSort($arr){  //获取需要排序的长度  $length=count($arr);  //假定第一个为有序的,所以从$i开始比较  for ($i=1; $i <$length ; $i++) {    //存放待比较的值    $tmp=$arr[$i];    for($j=$i-1;$j>=0;$j--){      //若插入值比较小,则将后面的元素后移一位,并将值插入      if($tmp<$arr[$j]){        $arr[$j+1]=$arr[$j];        $arr[$j]=$tmp;      }else{        break;      }    }  }  return $arr;}

算法时间复杂度计算

在最好的情况下(元素已经排好顺序):那么只需要循环 n-1 次就可以了,时间复杂度 O(n)
在最差的情况下(元素是逆序的):要循环调整次数: [ n * (n-1) ] / 2 ,时间复杂度为 O(n ^ 2)
平均时间复杂度为:O(n ^ 2)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持Gxl网。

您可能感兴趣的文章:

PHP实现桶排序算法的讲解

关于Laravel Service Provider开发设置延迟加载时遇到的问题详解

PHP实现排序堆排序算法

以上就是PHP排序算法系列之插入排序的详解的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的PHP排序算法系列之插入排序的详解全部内容,希望文章能够帮你解决PHP排序算法系列之插入排序的详解所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

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

扫码关注

qrcode

QQ交谈

回顶部