插入排序算法(Python版)

1、什么是插入排序算法

插入排序算法是一种简单直观的排序算法,它的基本思想是将一个元素逐个插入到已排序的序列中,从而构建出完整的有序序列。

插入排序算法的时间复杂度为O(n^2),其中n为待排序序列的长度。虽然插入排序在大规模数据上可能不如快速排序或归并排序等算法快速,但对于小规模或部分有序的数据,插入排序具有稳定性和简单性的优势。

2、具体步骤

  1. 从第二个元素开始,将当前元素视为已排序部分,将它与已排序的部分依次比较。
  2. 如果当前元素小于已排序部分的某个元素,则将这个元素后移一位,为当前元素腾出插入的位置。
  3. 将当前元素插入到正确的位置,使得插入后的序列仍然保持有序。
  4. 重复以上步骤,直到所有元素都被插入到正确的位置,完成排序。

3、代码示例

python 复制代码
def insertion_sort(arr):
    n = len(arr)
    for i in range(1, n):
        key = arr[i]
        j = i - 1
        while j >= 0 and key < arr[j]:
            arr[j + 1] = arr[j]
            j -= 1
        arr[j + 1] = key

# 示例用法
arr = [12, 11, 13, 5, 6]
insertion_sort(arr)
print("排序后的数组:", arr)

这段代码定义了一个名为insertion_sort的函数,用于对输入的数组进行插入排序。排序过程中,从第二个元素开始(索引为1),将当前元素与已排序的部分进行比较并插入正确的位置,直到整个数组排序完成。

相关推荐
码界奇点18 小时前
基于Python与Pygame的多功能游戏系统设计与实现
python·游戏·毕业设计·pygame·源代码管理
万邦科技Lafite18 小时前
一键获取淘宝店铺所有商品信息,实时监控商品数据
开发语言·数据库·python·api·开放api·电商开放平台·淘宝开放平台
小糖学代码19 小时前
LLM系列:1.python入门:2.数值型对象
人工智能·python·ai
CoderYanger19 小时前
动态规划算法-简单多状态dp问题:15.买卖股票的最佳时机含冷冻期
开发语言·算法·leetcode·动态规划·1024程序员节
Xの哲學19 小时前
Linux RTC深度剖析:从硬件原理到驱动实践
linux·服务器·算法·架构·边缘计算
狐5719 小时前
2025-12-04-牛客刷题笔记-25_12-4-质数统计
笔记·算法
小O的算法实验室19 小时前
2024年IEEE IOTJ SCI2区TOP,基于混合算法的水下物联网多AUV未知环境全覆盖搜索方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
零日失眠者19 小时前
这5个Python库一旦掌握就离不开
后端·python
用户83562907805119 小时前
如何使用 Python 从 Word 文档中批量提取表格数据
后端·python
洲星河ZXH19 小时前
Java,比较器
java·开发语言·算法