博客說明java
文章所涉及的資料來自互聯網整理和我的總結,意在於我的學習和經驗彙總,若有什麼地方侵權,請聯繫本人刪除,謝謝!數組
插入排序(Insertion Sorting)的基本思想是:把n個待排序的元素當作爲一個有序表和一個無序表,開始時有序表中只包含一個元素,無序表中包含有n-1個元素,排序過程當中每次從無序表中取出第一個元素,把它的排序碼依次與有序表元素的排序碼進行比較,將它插入到有序表中的適當位置,使之成爲新的有序表。網絡
package cn.guizimo.sort; import java.util.Arrays; public class InsertSort { public static void main(String[] args) { int[] arr = {12, 28, 3, 109, 50}; System.out.println("插入前"); System.out.println(Arrays.toString(arr)); insertSort(arr); System.out.println("插入後"); System.out.println(Arrays.toString(arr)); } public static void insertSort(int[] arr) { for (int i = 1; i < arr.length; i++) { int insertVal = arr[i]; int insertIndex = i - 1; while (insertIndex >= 0 && insertVal < arr[insertIndex]) { arr[insertIndex + 1] = arr[insertIndex]; insertIndex--; } if (insertIndex + 1 != i) { arr[insertIndex + 1] = insertVal; } System.out.println("第" + i + "輪插入"); System.out.println(Arrays.toString(arr)); } } }
package cn.guizimo.sort; public class InsertSort { public static void main(String[] args) { int max = 80000; int[] arr = new int[max]; for (int i = 0; i < max; i++) { arr[i] = (int)(Math.random() * 8000000); } long date1 = System.currentTimeMillis(); insertSort(arr); long date2 = System.currentTimeMillis(); System.out.println("冒泡排序"+max+"數組的時間爲:"+(date2-date1)); } public static void insertSort(int[] arr) { for (int i = 1; i < arr.length; i++) { int insertVal = arr[i]; int insertIndex = i - 1; while (insertIndex >= 0 && insertVal < arr[insertIndex]) { arr[insertIndex + 1] = arr[insertIndex]; insertIndex--; } if (insertIndex + 1 != i) { arr[insertIndex + 1] = insertVal; } } } }
感謝dom
尚硅谷學習
萬能的網絡測試
以及勤勞的本身
關注公衆號: 歸子莫,獲取更多的資料,還有更長的學習計劃ui