JS排序算法之希尔算法

希尔算法:
希尔算法在原理上也是一种插入排序,在了解希尔算法之前,必须了解插入排序;

原理:
希尔排序在插入排序的基础上,将数据进行了分组,将原有的数据分为若干个子集,然后对每个子集进行排序,依次类推,不停地分割成子集,直到最后完全排序。

数列:[3,5,2,4,7,6,8,9,1]
先将整个数列以gap为基准进行分割为子集,对子集进行排序;(gap 一般为 Math.floor(arr.length/2))
gap:4
分割后的子集为:3,7 ,1 5,6 2,8 4,9 是个子集
对子集进行排序后:1,3,7 5,6 2,8 4,9
数列为:[1,5,2,4,3,6,8,9,7]

修改gap的值 再次进行排序
gap:2
……..
直到gap的值为0则停止

JS代码实现:

var arr=[3,5,2,4,7,6,8,9,1];
var gap=Math.floor(arr.length/2);       
while(gap>0){
    for(var i=gap;i<arr.length;i++){
        var temp=arr[i];
        var j=i-gap;
        while(j>=0&&arr[j]>temp){
            arr[j+gap]=arr[j];
            arr[j]=temp;
            j-=gap;
        }
        arr[j+gap]=temp;
        }
    gap=Math.floor(gap/2); 
}

输出结果: [1, 2, 3, 4, 5, 6, 7, 8, 9]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值