希尔排序总结

希尔排序Shell Sort是插入排序的一种改进:在希尔排序中,有一个量叫做关键字(我理解为步长):step,这个关键字将待排序的数组分为step组,每组为至多arrayLen/step+1个元素(可能不能整除,那么钱array%step多一个元素),对每组的元素进行插入排序,减小step知道step为1。希尔排序的时间复杂度为:O(nlog(n))

举例:

准备待排数组[6 2 4 1 5 9]

首先需要选取关键字,例如关键是3和1(第一步分成三组,第二步分成一组),那么待排数组分成了以下三个虚拟组:

[6 1]一组

[2 5]二组

[4 9]三组

看仔细啊,不是临近的两个数字分组,而是3(分成了三组)的倍数的数字分成了一组,

就是每隔3个数取一个,每隔三个再取一个,这样取出来的数字放到一组,

把它们当成一组,但不实际分组,只是当成一组来看,所以上边的"组"实际上并不存在,只是为了说明分组关系

对以上三组分别进行插入排序变成下边这样

[1 6] [2 5] [4 9]

具体过程:

[6 1]6和1交换变成[1 6]

[2 5]2与5不动还是[2 5]

[4 9]4与9不动还是[4 9]

第一趟排序状态演示:

待排数组:[6 2 4 1 5 9]

排后数组:[1 2 4 6 5 9]

第二趟关键字取的是1,即每隔一个取一个组成新数组,实际上就是只有一组啦,隔一取一就全部取出来了嘛

此时待排数组为:[1 2 4 6 5 9]

直接对它进行插入排序

 

注意:在选取步长的时候必须保证最后一个增量必须为1,这样才能保证希尔排序的正确性

步长选取的一般规则:第一次取总长度的一半,第二次取一半的一半,依次累推直到1为止

 

希尔排序由于一般插入排序的原因:

1,一般插入排序在序列基本有序时效率比较高

2,一般插入排序在待排序元素比较少的时候效率比较高

3,希尔排序在刚开始时,步长比较大,分组比较多,所以每组的元素比较少

4,希尔排序在后来的时候,整个数组已经基本有序

比较直观的感觉就是,希尔排序可以让一个数一次跳跃比较大的一段,避免的一般排序都是后一个一个比较

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值