将一个记录插入到已经排序好的有序表中,从而得到一个新的有序表。可先将第一个数字作为初始的有序表,再将剩余的数次插入到这个有序表中。时间复杂度为O(n^2),是稳定的排序算法。
代码
void insertSort(int[] arr){
if (arr == null || arr.length == 0) {
return;
}
for (int i = 1; i < arr.length; i++) {
int j = i;
int tmp = arr[i];
// 将tmp插入到有序表中
while (j > 0 && (tmp < arr[j-1])){
// 有有序表的末尾开始往前遍历,如果大于tmp,就将该数字后移
arr[j] = arr[j-1];
j--;
}
arr[j] = tmp; // 将tmp插入到有序表中正确的位置
}
}
网友评论