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)
相关推荐
代码小将1 小时前
Leetcode209做题笔记
java·笔记·算法
Musennn2 小时前
leetcode 15.三数之和 思路分析
算法·leetcode·职场和发展
CM莫问5 小时前
<论文>(微软)避免推荐域外物品:基于LLM的受限生成式推荐
人工智能·算法·大模型·推荐算法·受限生成
康谋自动驾驶6 小时前
康谋分享 | 自动驾驶仿真进入“标准时代”:aiSim全面对接ASAM OpenX
人工智能·科技·算法·机器学习·自动驾驶·汽车
C++ 老炮儿的技术栈7 小时前
什么是函数重载?为什么 C 不支持函数重载,而 C++能支持函数重载?
c语言·开发语言·c++·qt·算法
yychen_java7 小时前
R-tree详解
java·算法·r-tree
MarkHard1238 小时前
Leetcode (力扣)做题记录 hot100(62,64,287,108)
算法·leetcode·职场和发展
王RuaRua8 小时前
[数据结构]5. 栈-Stack
linux·数据结构·数据库·链表
一只鱼^_8 小时前
牛客练习赛138(首篇万字题解???)
数据结构·c++·算法·贪心算法·动态规划·广度优先·图搜索算法
一只码代码的章鱼8 小时前
Spring的 @Validate注解详细分析
前端·spring boot·算法