希尔排序(C)

希尔排序

希尔排序的本质还是直接插入排序

影响直接插入排序速度的两个因素:

  1. 是否基本有序
  2. 序列长度

我们发现基本有序长度较短的速度更快。
所以希尔排序选择由大到小的不同增量使原序列满足这两个特点。

#include"../init.h"

void ShellInsert(RedType node[], int dk);

//希尔排序
//dlta[]是增量数组
void ShellSort(RedType node[], int dlta[], int len){
    //len 是dlta[]数组的长度
    int k = 0;
    for(; k< len; k++){
        ShellInsert(node,dlta[k]);
    }
}

/*eg:
    int d[] = {4,2,1};
    ShellSort(L.r,d,sizeof(d)/sizeof(int));
*/

//增量为dk的排序
void ShellInsert(RedType node[], int dk){
    RedType media;
    int i,j;
    for(i=dk; i < MAXSIZE; i++){
        if(node[i].key < node[i-1].key){
            media = node[i];
            for(j=i-dk; j>=0 && node[j].key > media.key; j-=dk){
                node[j+dk] = node[j];
            }
            node[j+dk] = media;
        }
    }
}

int main(){
    Sqlist L;
    int d[] = {4,2,1};
    init(L.r);
    ShellSort(L.r,d,sizeof(d)/sizeof(int));
    show(L.r);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值