增大移动步幅:
出发点:有序,移动一大步
基本思想:
分成若干个子序列后,再进行直接插入排序,等到待排序的记录基本有序时,再进行一次直接插入排序
例子:
选一个间隔为5,分割成若干子序列插入排序
再进行下一次3间隔的
最后一次做1间隔的,即直接插入排序
总结:
选一个增量序列,序列一个比一个小,是逐渐递减的,最后一定要做一个为1的,即直接插入排序
然后按照增量,对每一个增量进行间隔插入排序
特点:
算法:
对顺序表L,进行希尔排序,这个数组dlta[]放的是递减的增量序列
t,我们只用这个增量序列里的从t为0到t-1的t个元素作为增量序列
用循环来控制几趟,总共需要t趟
具体每一趟怎么做?
按照给定的增量dk,对顺序表L进行排序
每一次排序都实际上是一个插入排序,没什么区别,只不过这些元素的间隔不是1,而是我们给的这个增量序列
所以直接插入排序有几个要修改的,即下一个元素在哪里,这里不是-1,而是-dk,即我们要比较的是当前的位置减去间隔的位置上的元素
还有就是不断移动的时候,移动到哪里去呢?移动到间隔所在的位置j+dk
代码有问题
时间效率:与增量序列有关
这里也打错了
稳定性:不稳定
字体大的一组,字体小的一组,有两个相等的元素,排序后相对位置发生了改变,后面的跑前面,前面的跑后面
总结:经验公式:
元素的个数n和增量序列d的函数
临时存储单元
怎么取?最后一个必须为1.....不适合链式存储结构,因为要一个个数--那还不如用顺序查找法