插入排序是通過保證前n位是有序的,當第n+1位需要插入時,反向掃描前n位的大小,碰到大於該數的就向後移動一位,直到小於該數停止,即需要插入的位置。
示意圖:
代碼實現:
public static void insert(int[] arr) {
for (int i = 1; i < arr.length; i++) {
int tmp = arr[i];
int j = i - 1;
for (; j >= 0; j--) {
if (arr[j] > tmp) {
arr[j + 1] = arr[j];
}else{
break;
}
}
arr[j+1] = tmp;
System.out.println("第" + (i ) + "插入排序結果:" + Arrays.toString(arr));
}
}
public static void main(String[] args) {
int[] arr = {12, 3, 89, -9, 0};
insert(arr);
System.out.println(Arrays.toString(arr));
}
----------------------
第1插入排序結果:[3, 12, 89, -9, 0]
第2插入排序結果:[3, 12, 89, -9, 0]
第3插入排序結果:[-9, 3, 12, 89, 0]
第4插入排序結果:[-9, 0, 3, 12, 89]
[-9, 0, 3, 12, 89]