希尔排序(直接插入排序优化)

基本思想

  • 根据步长给序列分组,每组又通过直接插入排序算法进行排序,然后通过不断缩短步长,直接插入排序算法进行排序,直至步长为1,则序列排序完成。

直接插入与希尔排序适用情况

在这里插入图片描述

思路分析

  1. 选定步长gap,将 gap 位定为 i,则 i 与 i - gap位为一组序列
    在这里插入图片描述
  2. 通过直接插入排序将该序列进行排序,排序成功后,i 往后移动一位,直至 i = len,则第一趟排序成功
  3. 重复1、2,当gap = 1,整个序列排序成功

代码实现(c语言)

//非递减排序
void Shell_Insert_Sort(DataType arr[], int len)
{
    int gap;    //步长(间隔)
    int i, j, temp;

    for (gap = len >> 1; gap > 0; gap >>= 1)  
    {
        for (i = gap; i < len; i++)
        {
            temp = arr[i];
            //非递减排序
            //若为递减排序,则修改为arr[j] < temp
            for (j = i - gap; j >= 0 && arr[j] > temp; j -= gap)   
            {
                arr[j + gap] = arr[j];  //数据大的往后移动
            }
            arr[j + gap] = temp;    //temp放在合适的位置
        }
    }
}

性能分析

在这里插入图片描述

代码测试(c语言)

#include <stdio.h>

typedef char DataType;

void Shell_Insert_Sort(DataType arr[], int len)
{
    int gap;    //步长(间隔)
    int i, j, temp;

    for (gap = len >> 1; gap > 0; gap >>= 1)  
    {
        for (i = gap; i < len; i++)
        {
            temp = arr[i];
            //非递减排序
            //若为递减排序,则修改为arr[j] < temp
            for (j = i - gap; j >= 0 && arr[j] > temp; j -= gap)   
            {
                arr[j + gap] = arr[j];  //数据大的往后移动
            }
            arr[j + gap] = temp;    //temp放在合适的位置
        }
    }
}

int main()
{
	//关键字序列
    DataType arr[] = { 'c','a','d','b','f','s',
    			  	   'h','u','q','w','e','r', 
    			       't','y','i','o','p','g',
    			       'j','k','l','z','x','v',
    			       'n','m'};
	//序列长度
    int len = sizeof(arr) / sizeof(DataType);
    //希尔排序
    Shell_Insert_Sort(arr, len);
    //遍历序列
    for (int i = 0; i < len; i++)
    {
        printf("%c\n", arr[i]);
    }

	return 0;
}

资料参考

  1. 希尔排序
posted @ 2021-04-04 20:35  跌落星球  阅读(17)  评论(0编辑  收藏  举报