插入排序 --- Java版

算法思路

插入排序就是每一步都将一个待排数据按其大小插入到已经排序的数据中的适当位置,直到全部插入完毕。 非常类似于打牌时候一边抓牌一遍理牌的情形。
插入排序方法分直接插入排序和折半插入排序两种,这里只介绍直接插入排序。
  文字说比较抽象, 下面有个动态图链接🔗帮助理解:
插入排序动态演示图

算法实现

public class InsertionSort {

    public static void sort(Comparable[] a) {
        int N = a.length;
        for (int i = 0; i < N; i++)    // i表示现在正在遍历元素的下标
            //从遍历的那个元素开始向前进行比较,碰到比之前一个元素小就交换,
            //不然直接break(因为左边区域已经有序,若a[j]比a[j-1]大那么一定比a[j-2],a[j-3]...大,那就不用比较交换了)
            for (int j = i; j > 0; j--)    
                if (less(a, j, j - 1))
                    swap(a, j, j - 1);
                else
                    break;
    }

    private static boolean less(Comparable[] a, int i, int j) {
        if (a[i].compareTo(a[j]) < 0)
            return true;
        else
            return false;
    }

    private static void swap(Comparable[] a, int i, int j) {
        Comparable t = a[i];
        a[i] = a[j];
        a[j] = t;
    }
}

性能分析

  首先给一个前提,插入排序性能是有最好情况和最坏情况的,不一样。
  那哪种情况是最好情况?相信你猜出来了就是已经有序的待排数组的情况。如果数组已经有序, 那么看代码,里层循环永远不会执行(会执行break语句),所以只有外层循环起作用那么时间复杂度就是O(N)
  那哪种情况是最好情况?相信你也猜出来了就是完全逆序的待排数组的情况。数组完全逆序,插入第2个元素时要比较交换前1个元素,插入第3个元素时,要比较交换前2个元素,……,插入第N个元素,要比较交换前 N - 1 个元素。因此,最坏情况下的比较次数是 1 + 2 + 3 + ... + (N - 1),等差数列求和,结果为 N^2 / 2,所以最坏情况下的时间复杂度为 O(N^2)。空间复杂度则很直观O(1)。
  综上所述,通过某些数学证明(我目前不懂那个证明,还请网友告知)已经证明出,对于一个完全random且元素不重复的带排序数组,用插入排序平均需要 ¼ N^2 次比较和¼ N^2 交换操作。
  我大概只能从下面这张插入排序步骤图大概看出¼ N^2 这个数字的来源。因为每行灰色的是每次都不移动已经排序好的元素,黑色的是移动的元素,可以看出移动的元素面积大概是所有面积的1/4,这就是平均需要 ¼ N^2 次比较和¼ N^2 交换操作的直观证明。(但是我不知道怎么具体证明......)

algorithm4_princeton

拓展

  如果数组中倒序的元素数量小于数组大小的某个倍数,那么我们就说这个数组部分有序
有几种典型的部分有序数组:

  • 数组中每个元素距离它最终位置不远;
  • 一个基本有序的大数组接一个无序小数组;
  • 数组中只有几个元素位置不对;
    这些数组都适合用插入排序。

  逆序对:

对于一个包含N个非负整数的数组A[1..n],如果有i < j,且A[ i ]>A[ j ],则称(A[ i] ,A[ j] )为数组A中的一个逆序对。

inversion_pair.png

比如
上面这个数组就有6个逆序对。
这里有个定理: 插入排序需要的swap操作和数组中逆序对个数是一样的,需要compare操作的个数大于等于逆序对数目,但小于等于逆序对加上数组大小减1。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容

  • 一、 单项选择题(共71题) 对n个元素的序列进行冒泡排序时,最少的比较次数是( )。A. n ...
    貝影阅读 9,051评论 0 10
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 5,173评论 0 52
  • 排序的基本概念 在计算机程序开发过程中,经常需要一组数据元素(或记录)按某个关键字进行排序,排序完成的序列可用于快...
    Jack921阅读 1,423评论 1 4
  • 多益网络是内推。然后笔试,一面是HR面,二面是产品面,中间还有一道开放题,目前还没有接到结果,怕是要挂了。就这些经...
    柯秋阅读 17,600评论 10 20
  • 1早起 2运动 晚上跑去逛街了,没有练字 3记账完成哈
    连名带姓阅读 234评论 0 1