插入排序算法

插入排序(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. 不适用于大规模的数据排序,效率不如快速排序、归并排序等其他高效排序算法。

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

相关推荐
m0_6949380123 分钟前
Leetcode打卡:不含特殊楼层的最大连续楼层数
算法·leetcode·职场和发展
DogDaoDao27 分钟前
leetcode 面试经典 150 题:字母异位词分组
算法·leetcode·面试·vector·哈希表·数据结构与算法·字母异位词分组
tt55555555555536 分钟前
每日一题-两个链表的第一个公共结点
数据结构·算法·链表
jiayoushijie-泽宣1 小时前
VITA-1.5接近GPT4o水平的多模态模型:理解和跑通这套多模态实时交互系统
人工智能·算法·交互
Smark.1 小时前
(leetcode算法题)769. 最多能完成排序的块
算法·leetcode
Gpluso_od1 小时前
LeetCode -Hot100 - 73. 矩阵置零
算法·leetcode·矩阵
敲键盘的喵1 小时前
算法专题 —— 滑动窗口
算法
whpu_yb1 小时前
<代码随想录> 算法训练营-2025.01.04
算法
pzx_0012 小时前
【集成学习】Bagging算法详解及代码实现
python·算法·机器学习·集成学习
CM莫问2 小时前
<论文>什么是胶囊神经网络?
人工智能·深度学习·神经网络·算法·胶囊网络