13、数据结构与算法 - 基础:排序算法之插入排序
1、插入排序介绍
插入排序属于内部排序法,一般也被称为直接插入排序,对于少量元素排序来说是一个有效的算法。它是对要排序的元素以插入的方式找到元素的适当位置,达到排序的目的
2、插入排序思想:
把n个要排序的元素看成为一个有序表和一个无序表,开始时有序表中只包含一个元素,无序表中包含 n - 1 个元素,排序过程中每次从无序表中取出第一个元素,把它的排序码依次与有序表元素的排序码进行比较,将它插入到有序表中的适当位置,使它成为新的有序表
在待排序的元素中,假设前面 n - 1(其中 n >= 2)个数是排好序的
3、插入排序代码实现
public static void insertSort(int[] arr) {
for(int i = 1; i < arr.length; i++) {
// 临时变量,用来存储要要插入的值
int insertValue = arr[i];
// 要插入值前一个位置的下标
int insertIndex = i - 1;
// 判断下标未越界还在找要插入位置,并且要插入的值是否小于 arr[insertIndex] 的值
while (insertIndex >= 0 && insertValue < arr[insertIndex]) {
// 将要插入位置的值赋值给后一个
arr[insertIndex + 1] = arr[insertIndex];
// 继续向前找,前面的是已经排序好的数据,直到找到合适位置或者 index 小于 0
insertIndex --;
}
// 已经找到合适位置后将要插入的值 insertValue 赋值给 arr[insertIndex + 1]
arr[insertIndex + 1] = insertValue;
}
System.out.println(Arrays.toString(arr));
}