排序--希尔排序

希尔排序是基于插入排序的。

比如是个数为10的数组,
首先将增量设置为 10/2,就是5,将分组中,每5个进行分组,将分组后的每一组进行排序
之后再将增量设置为5/2,约等于3,将分组中,每3个进行分组,将分组后的每一组进行排序
以此类推,当增量为1的时候,就将整个数组进行排序。

function shellSort(nums){
               let len = nums.length
               // 先初始化增量
               let gap = Math.floor(len / 2)
               // 进行循环,增量减少
               while(gap >= 1){
                    // 以gap作为间隔,进行分组,进行插入操作
                    for(let i = gap;i < len;i++){
                         let temp = nums[i]
                         let j = i
                         // 就是插入排序
                         while(nums[j - gap] > temp && j > 0){
                              nums[j] = nums[j - gap]
                              j -= gap
                         }
                         nums[j] = temp
                    }
                    gap = Math.floor(gap / 2)
               }
          }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值