网络技术

找论坛
mb46348043
Lv2 太平洋舰队下士
太平洋舰队下士 贡献175,距离下一级还需25贡献
楼主
2018-01-08 09:44 0 0 只看楼主
电梯直达 
  PHP排序算法系列之插入排序详解
  插入排序
  有一个已经有序的数据序列,要求在这个已经排好的数据序列中插入一个数,但要求插入后此数据序列仍然有序,这个时候谭八爷系统开发就要用到一种新的排序方法——插入排序法,插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
  原理
  直接插入排序(Insertion Sort)的基本思想是:每次将一个待排序的记录,按其关键字大小插入到前面已经排好序的子序列中的适当位置,直到全部记录插入完成为止。
  设数组为a[0…n-1]。
  1.初始时,a[0]自成1个有序区,无序区为a[1..n-1]。令i=1
  2.将a并入当前的有序区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)

您需要登录后才可以发帖 登录 | 立即注册

其他登录方式:

常用表情
太平洋电脑网论坛帖子仅代表作者本人意见,不代表网站立场。请勿轻信特价、汇款、中奖等信息,
请勿轻易透露个人资料,因此产生的一切后果,PConline不承担任何责任
回复 发新帖 找论坛 反馈 回顶部