【一起学习排序算法】4 插入排序

栏目: 编程工具 · 发布时间: 6年前

内容简介:先看看Wikipedia的定义:所以插入排序的思路就是:可以通过动画演示理解, 以下网上找的两个动画。如果你想操作不同的参数来演示,可以上这个网站visualgo.net动手试试。

先看看Wikipedia的定义:

Insertion sort algorithm iterates, consuming one input element each repetition, and growing a sorted output list. Each iteration removes one element from the input data, finds the location it belongs within the sorted list, and inserts it there. It repeats until no input elements remain.

所以插入 排序 的思路就是:

  • 把列表分为两个部分,一部分是已经排好序,一部分待排序。(这一点和选择排序类似)
  • 初始将第一个元素作为有序子列为,然后每次迭代从有序序列中移除;然后将它插入到有序序列中的相应位置。
  • 重复以上步骤,直到到最后一个元素,则表示数组有序。

图示

可以通过动画演示理解, 以下网上找的两个动画。如果你想操作不同的参数来演示,可以上这个网站visualgo.net动手试试。

【一起学习排序算法】4 插入排序
【一起学习排序算法】4 插入排序

代码实现

关于代码,README中代码只有实现算法的函数,具体运行的代码,请查看该目录下的文件。

代码如下:

const insertSort = (array) => {
    // 不修改原数组
    const originValues = array.slice(); 

    // 初始将第一个元素指定为有序子列,从第2个元素开始插入,直到n-1元素 
    for (let i = 1; i < originValues.length; i++) {
        const currentValue = originValues[i];
        // 标记插入有序子列的位置
        let insertIndex = i;
        // 将当前元素从右到左与有序子列元素比较
        // 起始位置为当前元素前一个元素,即i-1,终止位置为0
        // 如果当前元素比该有序子列元素小,则该元素后移一位,并修改插入位置的游标
        for (let j = i-1; j > -1 && currentValue < originValues[j]; j--) {
           originValues[j+1] = originValues[j];
           insertIndex = j;
        }
        // 插入指定位置
        originValues[insertIndex] = currentValue;
    }

    return originValues;
};
复制代码

以上就是直接插入排序的代码实现。总体来说还是比较简单易懂,其实就类似于打扑克,不断将扑克牌按顺序插入指定位置。唯一可能有一点容易想不清楚的,就是有序子列的右移部分。想清楚一点,只要有序子列的该元素大于要插入的元素,该元素就要后移一位。

算法分析

1. 时间复杂度

排序算法中,两个元素的比较次数是影响运行时间的首要因素。所以我们可以通过这个层面来评估。

最优复杂度

当数组有序时,每一次迭代只有一次比较,所以总共有n-1次比较,复杂度为O(n)。

最差复杂度

当数组逆序时,每一次都要比较整个有序子列,比较次数为:

T(n) = 1 + 2 + ... + n-1 = n*n/2
复制代码

所以,最差复杂度是O(n 2 )。

2. 稳定性

因为比较元素是,相同值不会交换,所以插入算法是稳定的。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

创业时代

创业时代

付遥 / 中信出版社 / 2015-7 / 39.8元

香港人郭鑫年酷爱赛车,在驾车穿越隧道的时候,因为收发短信发生意外,他从被撞得破烂的车里爬出来时,兴奋地高喊:我有一个伟大的想法,手机上的对讲机,将要改变世界!他随即辞职来到北京,开始艰难的创业历程。 移动技术迅猛发展,正在颠覆互联网行业,郭鑫年误打误撞,对讲机用户数量急增,竟成为移动互联网的明星,他也因此置身于风口浪尖。三大互联网巨头为了抢夺手机入口大打出手,无不希望争夺这张通往未来移动市场......一起来看看 《创业时代》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具