黑马程序员技术交流社区
标题:
C语言之希尔排序
[打印本页]
作者:
strongfish
时间:
2015-7-15 10:26
标题:
C语言之希尔排序
将数组用希尔排序从小到大排序并输出.希尔排序是在直接插入排序的基础上做的改进,也就是将要排序的序列按固定增量分成若干组,等距离者在同一组中,然后再在组内进行直接插入排序.这里的固定增量从Size/2开始,以后每次缩小到原来的一半!
# include <stdio.h>
# define Size 10 //数组长度
int main()
{
int number[Size] = { 2, 4, 6, 7, 9, 5, 4, -4, 0, 10 };
int gap = Size / 2; //增量值
int temp;
while (gap > 0) //增量必须大于0
{
for (int i = gap; i < Size; i++) //数组行下标gap进行直接插入排序
{
temp = number[i];
int l = i - gap; //确定右边的需要进行比较的元素
while (l >= 0 && temp < number[l])
{
number[l + gap] = number[l]; //数据右移
l -= gap;
}
number[l + gap] = temp; //在确定的位置插入
}
gap /= 2;
}
for (int i = 0; i < Size; i++)
{
printf("%d ", number[i]);
}
return 0;
}
复制代码
注: 希尔排序是插入排序的一种, 分组插入排序。
作者:
Mr冷夏
时间:
2015-7-15 11:01
恩哦 啊,奥额呵哈。
作者:
huguozhang
时间:
2015-7-15 14:35
学习了~
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2