九大排序算法-插入排序

插入排序是通過保證前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]
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章