排序方法——插入排序

Posted peiyanh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了排序方法——插入排序相关的知识,希望对你有一定的参考价值。

  插入排序:是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

插入排序分析

技术分享图片

技术分享图片

function insert_sort(array){
    let len = array.length
    // 从第二个位置,即下标为1的元素开始向前插入
    for(let i = 1; i < len; i++){
        //  从第i个元素开始向前比较
        for(let j = i; j >= 0; j--){
            // 如果小于前一个元素,交换位置
            if(array[j] < array[j-1]){
                let mid = array[j]
                array[j] = array[j-1]
                array[j-1] = mid
            }
        }
    }
}

let arr = [54,26,93,17,77,31,44,55,20]

insert_sort(arr)
console.log(arr)
技术分享图片python

插入排序演示

技术分享图片

以上是关于排序方法——插入排序的主要内容,如果未能解决你的问题,请参考以下文章

7种基本排序算法的Java实现

《算法》笔记 3 - 选择排序插入排序希尔排序

JAVA代码[No.2]——插入排序详解

C# 各种内部排序方法的实现(直接插入排序希尔排序冒泡排序快速排序直接选择排序堆排序归并排序基数排序)

C# 各种内部排序方法的实现(直接插入排序希尔排序冒泡排序快速排序直接选择排序堆排序归并排序基数排序)

常用排序方法总结