排序算法之希尔排序
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;
}
动图展示:
以上是关于排序算法之希尔排序的主要内容,如果未能解决你的问题,请参考以下文章