插入排序算法

插入排序(Insertion Sort)是一种简单的排序算法,它的基本思想是将待排序的元素逐一插入到已排序的部分中,直到所有元素都被插入到正确的位置上。具体过程就像是你在玩扑克牌时,将牌插入到已经排好的牌中一样。

算法步骤:

  1. 从第二个元素开始,将当前元素与前面已经排序的部分进行比较。
  2. 找到合适的位置:将当前元素插入到已排序部分中,使得已排序部分仍然是有序的。
  3. 重复步骤1和2,直到所有元素都被插入到已排序的部分,最终完成排序。

插入排序的伪代码:

for i = 1 to length(A) - 1:
    key = A[i]  # 选择当前元素
    j = i - 1   # 在已排序部分查找位置
    while j >= 0 and A[j] > key:
        A[j + 1] = A[j]  # 将较大的元素往右移动
        j = j - 1
    A[j + 1] = key  # 将当前元素插入合适的位置

示例:

假设有一个数组 A = [5, 2, 9, 1, 5, 6],我们使用插入排序进行排序:

  1. 初始数组[5, 2, 9, 1, 5, 6]
  2. 第一轮(i=1) :选择 2,与 5 比较,发现 2 < 5,将 5 移动到后面,把 2 插入到第一个位置。
    • 结果:[2, 5, 9, 1, 5, 6]
  3. 第二轮(i=2) :选择 9,与 5 比较,发现 9 > 5,无需移动,继续下一个元素。
    • 结果:[2, 5, 9, 1, 5, 6]
  4. 第三轮(i=3) :选择 1,与 952 比较,发现 1 小于它们,将它们依次移动,将 1 插入到最前面。
    • 结果:[1, 2, 5, 9, 5, 6]
  5. 第四轮(i=4) :选择 5,与 9 比较,发现 5 < 9,将 9 移动到后面,继续与 5 比较,发现相等,无需移动,插入到对应位置。
    • 结果:[1, 2, 5, 5, 9, 6]
  6. 第五轮(i=5) :选择 6,与 9 比较,发现 6 < 9,将 9 移动到后面,与 5 比较,发现 6 > 5,插入到位置。
    • 结果:[1, 2, 5, 5, 6, 9]

最终排序后的数组是 [1, 2, 5, 5, 6, 9]

时间复杂度:

  • 最坏情况:当输入数组是倒序时,插入排序每次都需要与已经排好的元素进行比较,并将元素移动,时间复杂度是 O(n^2)。
  • 最好情况:当输入数组已经是有序的时,每次比较都不需要移动元素,时间复杂度是 O(n)。
  • 平均情况:平均时间复杂度为 O(n^2)。

空间复杂度:

插入排序是原地排序算法,其空间复杂度是 O(1)。

优缺点:

  • 优点
    1. 算法简单,易于实现。
    2. 对于小规模的数据排序,性能较好。
    3. 稳定排序:相等元素的相对位置不会改变。
    4. 如果输入数组已经基本有序,效率较高(最好情况时间复杂度 O(n))。
  • 缺点
    1. 对于大规模数据,性能较差,时间复杂度为 O(n^2)。
    2. 不适用于大规模的数据排序,效率不如快速排序、归并排序等其他高效排序算法。

插入排序适用于数据量较小或者数据基本有序的情况。

相关推荐
非 白2 小时前
数据结构——树
数据结构·笔记·考研
Dizzy.5174 小时前
数据结构(查找)
数据结构·学习·算法
分别努力读书7 小时前
acm培训 part 7
算法·图论
武乐乐~7 小时前
欢乐力扣:赎金信
算法·leetcode·职场和发展
Jared_devin7 小时前
数据结构——模拟栈例题B3619
数据结构
'Debug7 小时前
算法从0到100之【专题一】- 双指针第一练(数组划分、数组分块)
算法
sushang~7 小时前
leetcode21.合并两个有序链表
数据结构·链表
Fansv5877 小时前
深度学习-2.机械学习基础
人工智能·经验分享·python·深度学习·算法·机器学习
yatingliu20198 小时前
代码随想录算法训练营第六天| 242.有效的字母异位词 、349. 两个数组的交集、202. 快乐数 、1. 两数之和
c++·算法
uhakadotcom9 小时前
Google DeepMind最近发布了SigLIP 2
人工智能·算法·架构