插入排序:它的基本思想是将一个记录插入到已经排好序的有序表中,从而一个新的、记录数增1的有序表。在其实现过程使用双层循环,外层循环对除了第一个元素之外的所有元素,内层循环对当前元素前面有序表进行待插入位置查找,并进行移动。
对于少量元素的排序,它是一个有效的算法。
代码实现
public static void insertionSort(int[] arr) {
//因为我们i的起始值是1,所以我们判断条件需要是i<arr.length.才能执行length-1次。
for (int i = 1; i < arr.length; i++) {
int tempIndex = i;
int tempValue = arr[i];
for (int j = i - 1; j >= 0; j--) {
if (arr[tempIndex] < arr[j]) {
arr[j + 1] = arr[j];
tempIndex = j;
}
arr[tempIndex] = tempValue;
}
}
}













网友评论