2-插入排序

算法:插入排序 (属原址排序)

实现:将数据划分为三部分:待排数,待排序列,已排序序列;将待排数通过与已排序的序列从末端进行逐一对比,当待排数不大于当前对比数时将待排序插入对比数之后

时间复杂度: Θ ( n ) \Theta(n) Θ(n)~ Θ ( n 2 ) \Theta(n^2) Θ(n2)

python 复制代码
def insertion_sort(nums):
    for j in range(1, len(nums)): #待排序列
        x = nums[j] #待排数
        i = j - 1 # 已排序的终止索引
        while i >= 0 and nums[i] > x:
            nums[i + 1] = nums[i] #当对比数大于待排数时,对比数后移
            i -= 1 #继续与下一个对比数进行对比
        nums[i + 1] = x #当待排数不大于对比数时,将待排数插入对比数之后

if __name__ == '__main__':
    nums = [5, 2, 4, 6, 1, 3]
    insertion_sort(nums)
    print(nums)
相关推荐
guygg8822 分钟前
基于matlab的FIR滤波器
开发语言·算法·matlab
双叶83638 分钟前
(C++)学生管理系统(正式版)(map数组的应用)(string应用)(引用)(文件储存的应用)(C++教学)(C++项目)
c语言·开发语言·数据结构·c++
ysh98881 小时前
PP-OCR:一款实用的超轻量级OCR系统
算法
遇雪长安1 小时前
差分定位技术:原理、分类与应用场景
算法·分类·数据挖掘·rtk·差分定位
数通Dinner1 小时前
RSTP 拓扑收敛机制
网络·网络协议·tcp/ip·算法·信息与通信
张人玉3 小时前
C# 常量与变量
java·算法·c#
学不动CV了3 小时前
数据结构---链表结构体、指针深入理解(三)
c语言·arm开发·数据结构·stm32·单片机·链表
weixin_446122464 小时前
LinkedList剖析
算法
百年孤独_5 小时前
LeetCode 算法题解:链表与二叉树相关问题 打打卡
算法·leetcode·链表
我爱C编程5 小时前
基于拓扑结构检测的LDPC稀疏校验矩阵高阶环检测算法matlab仿真
算法·matlab·矩阵·ldpc·环检测