js 实现插入排序算法(希尔排序算法)

插入排序是一种简单直观的排序算法。主要方法就是从数组值一个一个取出进行排序。

特性:

  1. 原理简单,代码实现简洁,易于理解和手写;
  2. 对小规模数据(n<100)和基本有序的数据排序效率极高(接近 O(n) ),优于冒泡排序;
  3. 时间复杂度为 O(n^2) ,数据量大(n>1000),效率急剧下降;
javascript 复制代码
const insertSort = (arr) => {
    for(let i = 1;i < arr.length;i++) {
        const value = arr[i]
        let j = i - 1
        while(j >=0 && arr[j] > value) {
            arr[j+1] = arr[j]
            j--
        }
        arr[j+1] = value
    }
}

const arr = [1100,200,500,1600,25,13,685,23651,0,12,35,478,66,5,3,9,8,456,58,68,95,25,12,45,65,8,78,95,68,321,456,122,258,951,864,57,85,95,96,93,92,94,98,25,26,28,29,68,65,62,67,789,752,751,745,6859,3,20,359,215,687,592]
insertSort(arr)
console.log(arr)

希尔排序(Shell's Sort): 是插入排序的一种改进 算法,又称**"缩小增量排序"**(Diminishing Increment Sort),是Shell在1959年提出的。

javascript 复制代码
const shellSort = (arr) => {
    let n = arr.length
    let gap = Math.floor(n / 2)
    while(gap > 0) {
        for(let i = gap;i < n;i++) {
            const value = arr[i]
            let j = i - gap
            while(j >= 0 && arr[j] > value) {
                arr[j+gap] = arr[j]
                j -= gap
            }
            arr[j+gap] = value
        }
        gap = Math.floor(gap / 2)
    }
}

const arr = [1100,200,500,1600,25,13,685,23651,0,12,35,478,66,5,3,9,8,456,58,68,95,25,12,45,65,8,78,95,68,321,456,122,258,951,864,57,85,95,96,93,92,94,98,25,26,28,29,68,65,62,67,789,752,751,745,6859,3,20,359,215,687,592]
shellSort(arr)
console.log(arr)

gap的取法有多种,Knuth 提出 gap = | gap /3 | + 1 是效果比较好的。

javascript 复制代码
const shellSort = (arr) => {
    let n = arr.length
    let gap = n
    while(gap > 1) {
        gap = Math.floor(gap / 3) + 1
        for(let i = gap;i < n;i++) {
            const value = arr[i]
            let j = i - gap
            while(j >=0 && arr[j] > value) {
                arr[j+gap] = arr[j]
                j -= gap
            }
            arr[j+gap] = value
        }
    }
}

const arr = [1100,200,500,1600,25,13,685,23651,0,12,35,478,66,5,3,9,8,456,58,68,95,25,12,45,65,8,78,95,68,321,456,122,258,951,864,57,85,95,96,93,92,94,98,25,26,28,29,68,65,62,67,789,752,751,745,6859,3,20,359,215,687,592]
shellSort(arr)
console.log(arr)
相关推荐
折哥的程序人生 · 物流技术专研6 分钟前
Java面试85题图解版(一):基础核心篇
java·开发语言·后端·面试
AllData公司负责人22 分钟前
通过Postgresql同步到Doris,全视角演示AllData数据中台核心功能效果,涵盖:数据入湖仓,数据同步,数据处理,数据服务,BI可视化驾驶舱
java·大数据·数据库·数据仓库·人工智能·python·postgresql
Hello.Reader1 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
一只大袋鼠1 小时前
JavaWeb四种文件上传方式(下篇)
java·开发语言·springmvc·javaweb
TE-茶叶蛋1 小时前
深入研究 yudao-framework 模块:Java 编程能力提升指南
java·开发语言
逻辑驱动的ken1 小时前
Java高频考点场景题24
java·开发语言·面试·职场和发展·求职招聘
绛橘色的日落(。・∀・)ノ2 小时前
机器学习之评估与偏差方差分析
算法
兔小盈2 小时前
多线程-(五)线程安全之内存可见性
java·开发语言·多线程
消失的旧时光-19432 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
CeshirenTester2 小时前
LangChain的工具调用 vs 原生Skill API:性能差在哪儿?
java·人工智能·langchain