排序算法(3):插入排序

问题

排序 30, 24, 5, 58, 18, 36, 12, 42, 39

插入排序

插入排序将序列分为已排序和未排序两部分,每次从未排序部分取出第一个元素,插入到已排序部分的适当位置。重复此过程直到所有元素排序完成。

图解

  1. 初始化第一个元素为已排序部分,从未排序部分取第一个元素,插入到已排序部分的适当位置,主要是通过将大于待排序元素的位置后移
  2. 重复上述过程直到所有元素完成排序

代码

py 复制代码
def insertion_sort(nums):
    n = len(nums)
    for i in range(1, n):
        key = nums[i]
        j = i - 1

        while j >= 0 and key < nums[j]:
            nums[j + 1] = nums[j]	# 将大于目标值的元素后移
            j -= 1

        nums[j + 1] = key
    return nums

时间复杂度

插入排序的时间复杂度为 O(n2)

相关推荐
菜菜的顾清寒几秒前
力扣HOT100(49)动态规划 -- 打家劫舍
算法·leetcode·动态规划
葡萄城技术团队4 分钟前
观察生活:人是如何分词的
算法·生活
装不满的克莱因瓶9 分钟前
什么是特征分解?从数学定义到现实问题的映射
人工智能·数学·算法·机器学习·ai·特征分解
killerbasd14 分钟前
总结 6.1
算法
「維他檸檬茶」17 分钟前
大模型算法学习2026.6.1
学习·算法·大模型·nlp
玖釉-18 分钟前
LeetCode Hot 100 知识点总结与算法指南
c++·windows·算法·leetcode
填满你的记忆21 分钟前
《动态规划-基础篇》
算法·动态规划·力扣
进击的荆棘22 分钟前
优选算法——队列+宽搜
数据结构·c++·算法·leetcode·bfs·队列
黎阳之光24 分钟前
虚实同源·数智治水:黎阳之光视频孪生,重构智慧水务新范式
运维·物联网·算法·安全·数字孪生
江屿风26 分钟前
C++OJ题经验总结(竞赛)4
开发语言·c++·笔记·算法·dp·双指针