TypeScript十大排序算法插入排序实现示例详解


一. 插入排序的定义

插入排序就像是你打扑克牌,你从牌堆顶取一张牌,找到合适的位置插入到已有牌的顺序中,并不断重复这一步骤直到所有的牌都被 插入到合适的位置,最终使得整副牌有序。

与打牌类似,插入排序(Insertion sort)的实现方法是:

插入排序的优势在于它的性能表现在已经有序的序列上比冒泡排序、选择排序两种算法要好。

二. 插入排序的流程

插入排序的流程如下:

三. 插入排序的图解

四. 插入排序的代码

以下是 TypeScript 实现的插入排序代码,带有详细的注释:

function insertionSort(arr: number[]): number[] {  // 对于数组的每一个元素,从它开始到0位置,比较该元素和前一个元素的大小  for (let i = 1; i < arr.length; i++) {    let current = arr[i];    let j = i - 1;    // 如果该元素小于前一个元素,那么前一个元素向后移动,并继续向前比较    while (j >= 0 && arr[j] > current) {      arr[j + 1] = arr[j];      j--;    }    // 如果该元素大于前一个元素,那么它将放到合适的位置    arr[j + 1] = current;  }  // 返回排序后的数组  return arr;}// 测试数据const testArr = [5, 2, 9, 1, 5, 6];// 调用插入排序函数const sortedArr = insertionSort(testArr);// 打印结果console.log(sortedArr);

代码执行的过程:

五. 插入排序的时间复杂度

插入排序的时间复杂度在最好的情况下为O(n),在最坏的情况下为O(n^2),平均时间复杂度为O(n^2)。

当数据已经有序时,插入排序只需要做n-1次比较和0次移动,运行时间为O(n);

当数据完全逆序时,插入排序需要做n-1趟比较和3/2*(n-1)^2/2次移动,运行时间为O(n^2)。

由于插入排序的最好时间复杂度与最坏时间复杂度都接近O(n^2),所以插入排序适用于数据规模不大的场合,如果数据规模很大,通常使用其他算法。

六. 插入排序的总结

总而言之,如果数组部分有序,插入排序可以比冒泡排序和选择排序更快。

以上就是TypeScript十大排序算法插入排序实现示例详解的详细内容