簡述
插入排序(Insertion-Sort)的算法描述是一種簡單直觀的排序算法。它的工作原理是通過構建有序序列,對於未排序數據,在已排序序列中從后向前掃描,找到相應位置並插入。插入排序在實現上,通常采用in-place排序(即只需用到O(1)的額外空間的排序),因而在從后向前掃描過程中,需要反復把已排序元素逐步向后挪位,為最新元素提供插入空間。
動圖演示
看下面動圖演示,就能很容易理解上面所述內容。
(算法動圖來源於參考資料,詳細請往下翻閱)
代碼實現
1 /** 2 * 插入排序 3 * @param array 4 * @return 5 */ 6 public static int[] insertionSort(int[] array) { 7 int len; 8 // 基本情況下的數組可以直接返回 9 if(array == null || (len = array.length) == 0 || len == 1) { 10 return array; 11 } 12 int current; 13 for (int i = 0; i < len - 1; i++) { 14 // 第一個數默認已排序,從第二個數開始 15 current = array[i + 1]; 16 // 前一個數的下標 17 int preIdx = i; 18 19 // 拿當前的數與之前已排序序列逐一往前比較, 20 // 如果比較的數據比當前的大,就把該數往后挪一步 21 while (preIdx >= 0 && current < array[preIdx]) { 22 array[preIdx + 1] = array[preIdx]; 23 preIdx--; 24 } 25 // while循環跳出說明找到了位置 26 array[preIdx + 1] = current; 27 } 28 return array; 29 }
算法分析
最佳情況:T(n) = O(n) 最壞情況:T(n) = O(n2) 平均情況:T(n) = O(n2)
參考資料
1、https://www.cnblogs.com/guoyaohua/p/8600214.html