希尔排序基本思想和算法代码

先取一个小于n的整数d1作为第一个增量,把文件的全部记录分组。所有距离为d1的倍数的记录放在同一个组中。先在各组内进行直接插入排序;然后,取第二个增量d2<d1重复上述的分组和排序,直至所取的增量 =1( < …<d2<d1),即所有记录放在同一组中进行直接插入排序为止。
该方法实质上是一种分组插入方法
比较相隔较远距离(称为增量)的数,使得数移动时能跨过多个元素,则进行一次比较就可能消除多个元素交换。D.L.shell于1959年在以他名字命名的排序算法中实现了这一思想。算法先将要排序的一组数按某个增量d分成若干组,每组中记录的下标相差d.对每组中全部元素进行排序,然后再用一个较小的增量对它进行,在每组中再进行排序。当增量减到1时,整个要排序的数被分成一组,排序完成。
一般的初次取序列的一半为增量,以后每次减半,直到增量为1。

假设待排序文件有10个记录,其关键字分别是:
592,401,874,141,348,72,911,887,820,283。
增量序列的取值依次为:
5,2,1

在这里插入图片描述
操作步骤:
(1)相隔距离为gap= 5 的元素组成一组,可以分为 5 组,按照直接插入排序的方法对每个组进行排序。
(2)再上次的 gap 缩小一半,即 gap= gap / 2 = 2 (取整数)。这样每相隔距离为 2 的元素组成一组,可以分为 2 组,按照直接插入排序的方法对每个组进行排序。
(3)在第三趟排序中,再次把 gap 缩小一半,即gap = gap / 2 = 1。 这样相隔距离为 1 的元素组成一组,即只有一组,按照直接插入排序的方法对每个组进行排序。此时,排序已经结束。

算法实现

  public static void shellSort(int a[]) {
 
                            intd= a.length;//gap的值
 
                            while (true){
 
                                   d = d/ 2;//每次都将gap的值减半
 
                                   for (int x = 0; x< d; x++) {//对于gap所分的每一个组
 
                                          for (int i = x+ d; i < a.length; i= i + d) {      //进行插入排序
 
                                                 int temp= a[i];
 
                                                 intj;
 
                                                 for (j= i - d; j>= 0 && a[j] > temp;j = j - d){
                                                        a[j+ d] = a[j];
                                                 }
                                                 a[j+ d] = temp;
                                          }
                                   }
                                   if (d== 1) {//gap==1,跳出循环
                                          break;
                                   }
                            }
       }

最坏情况下时间复杂度:O(N*logN),最坏的情况下和平均情况下差不多。
在排序过程中,需要一个临时变量存储要插入的值,所以空间复杂度为1。
希尔排序中相等数据可能会交换位置,所以希尔排序是不稳定的算法。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值