将数组用希尔排序从小到大排序并输出.希尔排序是在直接插入排序的基础上做的改进,也就是将要排序的序列按固定增量分成若干组,等距离者在同一组中,然后再在组内进行直接插入排序.这里的固定增量从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;
- }
复制代码
注: 希尔排序是插入排序的一种, 分组插入排序。 |
|