希尔排序

参考文章
http://www.cnblogs.com/hapjin/p/5538411.html
http://www.cnblogs.com/jingmoxukong/p/4303279.html

希尔排序就是一个特殊形式的插入排序,插入排序是前面的都是有序的,轮到你的时候,你看到前面哪个比你大,你就再往前看,一直看到比你小的那个,然后吧唧插在这个后面,那些比你大的都往后站

希尔排序是这样,比如我有100个数,那我假设取一个5作为步长(听说比较好的步长序列是1, 5, 19, 41…),那我选出来的数的序号是[1,6,11,16…],然后对这批数做一个插入排序,然后再换一个步长,一般肯定选一个更小的步长咯,再来一次,然后一直到步长为1,完成

function shellsort(arr, gap) {
    for (var gap_t = gap; gap_t >= 1; gap_t = Math.floor(gap_t / 2)) {//更新gap
        for (var i = gap_t; i < arr.length; i++) {//这里要注意,是i++不是i+gap_t没错
            var tmp = arr[i];
            for (var j = i; j >= gap_t && tmp > arr[j - gap_t]; j = j - gap_t) {
                arr[j] = arr[j - gap_t]; //后移
            }
            arr[j] = tmp; //找到位置插入            
        }
        console.log(arr);
    }
}


shellsort([81,94,11,96,12,35,17,95,28,58,41,75,15],2);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值