希尔排序算法

增大移动步幅:

出发点:有序,移动一大步

基本思想:

分成若干个子序列后,再进行直接插入排序,等到待排序的记录基本有序时,再进行一次直接插入排序

例子:

选一个间隔为5,分割成若干子序列插入排序

 

再进行下一次3间隔的

最后一次做1间隔的,即直接插入排序

总结:

选一个增量序列,序列一个比一个小,是逐渐递减的,最后一定要做一个为1的,即直接插入排序

然后按照增量,对每一个增量进行间隔插入排序

特点:

 

算法:

 

对顺序表L,进行希尔排序,这个数组dlta[]放的是递减的增量序列

t,我们只用这个增量序列里的从t为0到t-1的t个元素作为增量序列

 

用循环来控制几趟,总共需要t趟

具体每一趟怎么做?

按照给定的增量dk,对顺序表L进行排序

每一次排序都实际上是一个插入排序,没什么区别,只不过这些元素的间隔不是1,而是我们给的这个增量序列

所以直接插入排序有几个要修改的,即下一个元素在哪里,这里不是-1,而是-dk,即我们要比较的是当前的位置减去间隔的位置上的元素

还有就是不断移动的时候,移动到哪里去呢?移动到间隔所在的位置j+dk

代码有问题

时间效率:与增量序列有关

这里也打错了

稳定性:不稳定

 

字体大的一组,字体小的一组,有两个相等的元素,排序后相对位置发生了改变,后面的跑前面,前面的跑后面

总结:经验公式:

元素的个数n和增量序列d的函数

临时存储单元

怎么取?最后一个必须为1.....不适合链式存储结构,因为要一个个数--那还不如用顺序查找法

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值