希 尔 排 序

基本思想:将整个无序序列分割成若干小的子序列分别进行插入排序。

序列分割方法:将相隔某个增量h的元素构成一个子序列。在排序过程中,逐次减小这个增量,最后当h减到1时,进行一次插入排序,排序就完成。增量序列一般采用:ht=2t-1,1≤t≤[log2n],其中n为待排序序列的长度。

    C函数如下:

  void prshl(p,n)

  int n;double p[];

  {

   int k,j,i;

   double t;

   k=n/2;

   while(k>0)

   {

    for(j=k;j<=n-1;j++)

    {

      t=p[j];i=j-k;

      while((i>=0)&&(p[i]>t))

        {

         p[i+k]=p[i];i=i-k;

         }

       p[i+k]=t;

      }

      k=k/2;

     }

   return;

  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值