插入排序
插入排序
一、算法描述
1.1 核心思想
- 数据分为已排序区间和未排序区间
- 插入都是从未排序区间取出元素,插入到已排序区间合适的位置中
- 插入已排序区间时,同时要保证已排序区间的有序性
1.2 细节解释
比如说,数组 [2, 7, 1, 4, 3, 6, 5]
。
首先分成未排序和已排序区间,第 1 个值无需排序,默认属于已排序区间:
1 | 已排序 未排序 |
此时从未排序区间中取一个值 7,插入到已排序区间:
因为 7 > 2
,所以 7 直接插入到 2 后面:
1 | 已排序 未排序 |
继续从未排序区间取值 1,此时 1 < 7
、1 < 2
,所以插入到 2 前面:
1 | 已排序 未排序 |
以此类推,后面每一步的结果如下:
插入 4:
1 | 已排序 未排序 |
插入 3:
1 | 已排序 未排序 |
插入 6:
1 | 已排序 未排序 |
插入 5:
1 | 已排序 未排序 |
经过 n 轮插入以后,数组就排好序了。
二、算法实现
1 | public void insertSort(int[] arr) { |
执行过程如下:
1 | ===== 初始数组 ===== |
三、算法分析
3.1 时间复杂度
- 最好时间复杂度:O(n)
- 最坏时间复杂度:O(n^2)
- 平均时间复杂度:O(n^2)
3.2 空间复杂度
- 空间复杂度:O(1)
- 原地算法
3.3 稳定性
- 稳定排序算法
附录
1 | /** |