概念及其介绍:
希尔排序算法是更一种高效的插入排序算法,和普通的插入排序算法相比,希尔排序算法减少了对元素的大小比较和移动元素的次数,从而提高了算法的效率。
过程演示:
按照每4个间隔将数组分成子数组
对应比较和交换之后数组变成了这样
间隔 2 个元素,再次划分整个序列:
采用插入排序算法分别对 {14, 27, 35, 42} 和 {19, 10, 33, 44} 进行排序:
变成这样之后在进行一次插入排序进行排序就完成了对数组的排序
待排序序列如何进行划分,划分多少次,都会影响到希尔排序算法的执行效率。
希尔排序算法没有固定的划分标准,这里给大家推荐一种常用的方法,套用如下伪代码:
输入 list //输入待排序序列 interval <- 1 // 初始值为 1 while interval < length(list) / 3: // length(list) 表示待排序序列的长度 interval = interval * 3 + 1
经过计算得出的 interval 的值,就是首次划分序列采用的标准。
后续划分整个序列,套用如下公式:
interval = (interval-1)/3
比如说计算第二次划分序列的标准,只需将第一次划分序列时计算得到的 interval 代入公式,求出的新 interval 值就是第二次采用的划分标准。
代码实现:
void the_shall_sort(int arr[],int se)
{
int temp, i, j;
int interval = 1;//初始化间隔为1
//首先计算出进行分割的最大间隔
//利用公式计算出最大间隔 interval = interval * 3 -1
while (interval < se / 3)
{
interval = interval * 3 - 1;
}
//此时interval 的值已经改变为最大间隔
//然后此时在进行分割数组,分成相对大小的子数组,并对相对的子数组进行插入排序
while (interval)
{
//让i直接从interval开始,
for (i = interval; i < se; i++)
{
temp = arr[i];
j = i;//记录下标
while (j > interval - 1 && arr[j - interval] >= temp)
{
arr[j] = arr[j - interval];
j -= interval;
}
if (j != i)
{
arr[j] = temp;
}
}
interval = (interval - 1) / 3;
}
}