/* ShellSort.c - by Chimomo 希尔排序又称“缩小增量排序”,是对直接插入排序方法的改进。 希尔排序的基本思想是:先将整个待排序序列分割成若干子序列,然后分别进行直接插入排序,待整个序列中的记录基本有序时,再对全体记录进行一次直接插入排序。 具体做法是:先取一个小于n的整数d1作为第一个增量,将所有距离为d1倍数的记录放在同一个组中,从而把全部记录分成d1组,在各组内进行直接插入排序;然后取第二个增量d2(d2<d1),重复上述分组和排序工作,依此类推,直至所取的增量di=1(di<...<d2<d1),即所有记录放在同一组进行直接插入排序为止。 希尔排序是不稳定的排序方法。 */ void ShellSort(int data[], int n) { int *delta, k, i, t, dk, j; /*从k = n开始,重复k = k / 2运算,直到k = 0,所得k值的序列作为增量序列存入delta*/ k = n; delta = (int *)malloc(sizeof(int) * (n / 2)); i = 0; do { k = k / 2; delta[i++] = k; } while(k > 0); i = 0; while((dk = delta[i]) > 0) { for(k = delta[i]; k < n; ++k) { /*将元素data[k]插入到有序增量子表中*/ if(data[k] < data[k - dk]) { /*备份待插入的元素,空出一个元素位置*/ t = data[k]; for(j = k - dk; j >= 0 && t < data[j]; j -= dk) { /*寻找插入位置的同时元素后移*/ data[j + dk] = data[j]; } /*找到插入位置,插入元素*/ data[j + dk] = t; } } /*取下一个增量值*/ ++i; } }
/* Main.c - by Chimomo */ main() { int i, a[] = {48, 37, 64, 96, 75, 12, 26, 48, 54, 3}; printf("Original array:\n"); for(i = 0; i < 10; i++) { printf("%d ", a[i]); } printf("\n"); ShellSort(a, 10); printf("Shell sorted array:\n"); for(i = 0; i < 10; i++) { printf("%d ", a[i]); } printf("\n"); }
原文地址:http://blog.csdn.net/troubleshooter/article/details/41597855