排序算法之希尔排序

Posted 数据结构C语言版

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了排序算法之希尔排序相关的知识,希望对你有一定的参考价值。

八大排序算法之希尔排序

No.1  基本思想

算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每组中再进行直接插入排序。当增量减到1时,进行直接插入排序后,排序完成。

No.2 实例

排序算法之希尔排序


No.3  C语言程序实现

程序框可以左右滑动哦~
#include<stdio.h>
#include<math.h>
#include<windows.h>
int main()
{
   int a[] = {1,54,6,3,78,34,12,45,56,100};
   int n= 10,d1=10;
   int temp,i,j,x,d;
   for(i=0;i<n;i++)
   {
       printf("%d\t",a[i]);
   }
   printf("\n");
   while(true)
   {
       d1 = ceil(d1/2);
       d = (int)d1;
       for(x=0;x<d;x++)
       {
           for(i=x+d;i<n;i=i+d)
           {
               temp = a[i];
               for(j=i-d;j>=x && temp<a[j];j=j-d)
               {
                   a[j+d] = a[j];
               }
               a[j+d] = temp;
           }
       }
       if(d == 1)
           break;
   }
   for(i=0;i<n;i++)
   {
       printf("%d\t",a[i]);
   }
   printf("\n");
   system("pause");
   return 0;
}



动图展示:



以上是关于排序算法之希尔排序的主要内容,如果未能解决你的问题,请参考以下文章

图解排序算法之希尔排序

图解排序算法之希尔排序

图解排序算法之希尔排序

排序算法入门之希尔排序(java实现)

重温基础算法内部排序之希尔排序法

算法之希尔排序快速排序二分查找