插入排序-java版


1. 插入排序

1.1 插入排序的基本介紹

插入排序屬於內排,就是以插入的方式來達到排序的目的

1.2 插入排序思想

將待排序的數組看成一個有序列表和一個無序列表。剛開始時有序列表只有一個元素 arr[0],無序列表有n-2 的數據 arr[1] ~ arr[n-1]。排序開始,每次從無序列表中取出第一個元素,找到相應的位置,並將其按照插入有序列表中。

1.3 插入排序的時間複雜度和空間複雜度等

算法名稱 平均時間複雜度 最好情況 最壞情況 空間複雜度 穩定性
插入排序 O(n^2) O(n) O(n^2) O(1) 穩定

2. 代碼演示


/**
 * @author shengjk1
 * @date 2020/4/9
 */
public class InsertSort {
	public static void main(String[] args) {
		int[] arr = new int[8];
		for (int i = 0; i < 8; i++) {
			arr[i] = (int) (Math.random() * 80000000);
		}

		for (int i = 1; i < arr.length; i++) {
			int insertIndex = i;
			int insertValue = arr[insertIndex];
			
			//找到相應的位置
			while (insertIndex - 1 >= 0 && arr[insertIndex - 1] > insertValue) {
				arr[insertIndex] = arr[insertIndex - 1];
				insertIndex--;
			}
			//並將其按照插入有序列表中
			arr[insertIndex] = insertValue;
			System.out.printf("第%d次遍歷 insertIndex %d arr:%s", i, insertIndex, Arrays.toString(arr));
			System.out.println();
		}
	}
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章