2.8 思维更重要:希尔排序

                                                希尔排序


一、基本思想

简介

希尔排序也是一种插入排序,他是简单插入排序经过改进之后的一个更高效的版本,也称缩小增量排序。

既然希尔排序是插入排序的高级版,那它做了哪些优化呢??让我们来看看:

  • 希尔排序在排序前:将一个序列分成了好几个序列

  • 在第一趟排序时:将这几个序列做插入排序

  • 在第二趟排序时:将这个序列又分了好几个序列做插入排序。

  • ................

  • 在第n趟排序时:将原序列进行插入排序,从宏观上看,此序列就基本是有序的了。这时就用简单插入排序将数列直至已序

从直观上看希尔排序:

  • 就是把数列进行分组(不停使用插入排序),直至从宏观上看起来有序,最后插入排序起来就容易了(无须多次移位或交换)。

那么,上面那里说了将一个序列分成好几个序列,那么到底怎么分呢?比如有10个元素的序列,分成几个才合适?每次缩减又是多少呢?

从专业的角度上讲,将一个序列分成好几个序列,用一个数来表示:那个数称为增量。显然的是,增量是不断递减的(直到增量为1)

往往的:如果一个数列有10个元素,我们第一趟的增量是5,第二趟的增量是2,第三趟的增量是1。如果一个数列有18个严肃,我们第一趟的增量是9,第二趟的增量是4,第三趟的增量是2,第四趟的增量是1

很明显我们可以用一个序列来表示增量:{n/2,(n/2)/2...1}每次增量都/2。

二、排序过程

    

三、实现代码

public static void shellSort(int[] nums){
    for(int increase = nums.length/2;increase > 0;increase/=2){//increase为希尔排序增量
        //对每一个增量序列进行插入排序
        for(int i = increase;i<nums.length;i++){
            int target = nums[i];
            int j = i - increase;
            while(j>=0 && target<nums[j]){
                nums[j+increase] = nums[j];
                j = j - increase;
            }
            nums[j+increase] = target;
        }
    }
}

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值