shell排序

 原理:

shell排序基于直接插入排序改进,把整个序列分割成多个部分进行插入排序,在进行子序列合并,在进行插入排序;这样减少移动空间次数。


 shell排序功能函数:

void shell_sort(sqlist_t *q) 
{
    int i, j;
    int count = q->last;

    do  
    {   
        count = count/3 + 1;    //增量序列
        for(i = count +1; i < q->last; i++)
        {
            if(q->data[i - count] > q->data[i])
            {
                //需将q->data[i]插入有序增量子表
                q->data[0] = q->data[i];               //暂存q->data[0] 
                for(j = i-count; j>0 && q->data[0] < q->data[j]; j -= count)
                    q->data[j+count] = q->data[j];    //记录后移,查找插入位置
                q->data[j+count] = q->data[0];        //插入
            }
        }
    }   
    while(count > 1); 
}

 执行函数:

int main(int argc, char *argv[])
{ 
    srand(time(NULL));
    sqlist_t *q = sqlist_create();
    for(int i = 1; i < 10; i++)
        q->data[i] = rand() % 100;
    printf("\n");

    for(int i = 1; i < 10; i++)
        printf("%3d ",q->data[i]);
    printf("\n");

    shell_sort(q);
    for(int i = 1; i < 10; i++)
        printf("%3d ",q->data[i]);
    printf("\n");


    return 0;
}

 运行结果:

.3);最坏的时间复杂度为O(n^2)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值