gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 32 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章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代码实现 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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) 。

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

原文链接:http://blog.csdn.net/qq_32300363/article/details/70225460 。

最后此篇关于PHP排序算法系列之插入排序详解的文章就讲到这里了,如果你想了解更多关于PHP排序算法系列之插入排序详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com