编辑代码

class Main {
    public static void insertSort1(int [] arr) {
        if(arr == null || arr.length < 2) {
            return;
        }
        // 0 ~ 0 完成
        // 0 ~ 1
        // 0 ~ 2
        // 0 ~ 3
        // 0 ~ n-1
        int N = arr.length;
        for(int end = 1; end < N; end++) {
            int newNumIndex = end;
            while(newNumIndex - 1 >= 0 && arr[newNumIndex - 1] > arr[newNumIndex]) {
                swap(arr, newNumIndex - 1, newNumIndex);
                newNumIndex--;
            }
        }
    }

    public static void insertSort2(int [] arr) {
        if(arr == null || arr.length < 2) {
            return;
        }
        int N = arr.length;
        for(int end = 1; end < N; end++) {
            for(int pre = end - 1; pre >= 0 && arr[pre] > arr[pre+1]; pre--) {
                swap(arr, pre, pre + 1);
            }
        }
    }

    public static void swap(int [] arr, int i, int j) {
        int tmp = arr[i];
        arr[i] = arr[j];
        arr[j] = tmp;
    }

    public static void printArr(int[] arr) {
        for(int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }

	public static void main(String[] args) {
       int[] arr = { 7, 1, 3, 5, 6, 8, 2 };
       insertSort1(arr);
       printArr(arr);
       System.out.println();
       int[] arr2 = { 7, 1, 3, 5, 6, 8, 2 };
       insertSort2(arr2);
       printArr(arr2);
	}
}