1. 程式人生 > >排序-InsertionSort 插入排序

排序-InsertionSort 插入排序

時間 -s 交換 -1 tro one 代碼 位置 git

插入排序 implementation


  插入排序就像打賭的時候,比如雙扣。抽牌的時候,一次拿一張牌,這張牌和之前的牌一張張比較。選擇把這張牌插入什麽位置,排好順序的位置後打牌更順。要不然得一個一個找到時麻煩。也不利於打牌的大局觀。看下圖

  假設第一次抽到梅花7, 不用排序。因為只有一張技術分享

  接著抽到梅花10 技術分享。因為10比7大,所以不用排序。

  再接著抽卡。發現抽到了梅花5 技術分享。這個時候不要猶豫,2點真的不算大的。果斷棄牌

  接著我們拿 5 和 10 比較。 5 小於 10 所以交換位置。技術分享

  拿5再和7比。 5 比 7 小。 所以交換 5 和 7 的位置 得到技術分享

  這個時候就已經是sorted的了。 原理就是這樣子。

  因為比較簡單。直接貼上代碼

  

技術分享
    // O(n^2) 最壞的情況
    // 最好的情況 O(n)
    public static void sort(Comparable[] a) {
        for (int i = 1; i < a.length; i++) {
            for (int j = i ; j > 0; j--) {
                if (less(a[j], a[j - 1])) 
                    exch(a, j, j - 1);
                else
                    break
; } } } public static void sort(Comparable[] a, int low, int hi) { for (int i = low; i <= hi ; i++) { for (int j = i ; j > low; j--) { if (less(a[j], a[j - 1])) exch(a, j, j - 1); else break
; } } }
InsertSort

  完整的代碼在https://github.com/Cheemion/algorithms/blob/master/src/com/algorithms/sort/InsertionSort.java

  性能分析


  最壞的情況就是每次抽到的卡是最小的。這個時候每次都需要從尾部遍歷到頭部。時間是N ^ 2成正比

  最好的情況就是已經排好序了。因為已經排好序了。所以每次抽到的牌都不需要排序。 時間是 N 成正比

  

  

  

  

  

  

排序-InsertionSort 插入排序