希尔排序

参考文章:https://www.cnblogs.com/chengxiao/p/6104371.html

上面这篇文章写的相当棒!

    《算法》中有描述:希尔排序是目前唯一无法准确描述其性能特征的排序算法,也是第一批突破O(n^2)的排序算法,希尔排序基于插入排序,基本思想是对数据进行分组,再进行宏观上的“模糊”调整,最后再“仔细”的微调,完成排序。

这张图就是上面文章中出现的,非常生动:


以java代码描述:

package sort;

/**
 * Created by 灵魂都在冒香气的神 on 2018/2/27.
 * 希尔排序
 */
public class ShellSort
{
    public static void sort(int[] a,int factor)
    {
        if (factor>a.length)
        {
            throw new IllegalArgumentException("the factor must smaller than num.length");
        }
        for (int gap=a.length/factor;gap>0;gap/=factor)
        {
            for (int i=gap;i<a.length;i++)
            {
                for (int j=i;j>=gap&&a[j]<a[j-gap];j-=gap)
                {
                    Util.swap(a,j,j-gap);
                }
            }
        }
    }
}

十万个数据下的测试结果:


效率已经相当高了,不过还是干不过java内置的Arrays.sort()快排^_^

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值