Python 实现插入排序

插入排序适合于部分有序序列和小规模的数据。其平均时间复杂度为 O(N^2),空间复杂度为 O(1),并且为稳定排序。

插入排序将待排序序列分为有序区 (记为 S 区)和无序区(记为 R 区)。以从小到大的顺序为例,每次从 R 区弹出一个元素 O,要将元素 O 插入到 S 区中恰当位置。从 S 区最右端开始,依次比较 S 区元素与元素 O 的大小。如果元素O 比 S 区元素小,就将 S 区元素后移一位。如果元素 O 大于 S 区元素,就在该元素右边一位插入元素 O。

import random

# Python高效编程
def insertionSort(sequence):
    seq = sequence[:]
    for i in range(1, len(seq)):
        value = seq[i]
        j = i - 1
        while j >= 0 and seq[j] > value:
            seq[j+1] = seq[j]
            j -= 1
        # j 在上面多减了 1,要加回来
        seq[j+1] = value
    return seq

random.seed(520)
seq = [random.randint(1, 100) for _ in range(12)]
print(seq)
print(insertionSort(seq))
#[2, 8, 51, 52, 18, 58, 56, 98, 54, 27, 32, 50]
#[2, 8, 18, 27, 32, 50, 51, 52, 54, 56, 58, 98]
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 5,013评论 0 2
  • 1)这本书为什么值得看: Python语言描述,如果学的Python用这本书学数据结构更合适 2016年出版,内容...
    孙怀阔阅读 14,318评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,583评论 0 52
  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 11,304评论 0 13
  • 谈相聚,喜相聚,相聚飞花雨。添岁更风情,三友蓉城叙。 红衫美酒遇,再忆经年去。同窗舞梅枝,深醉春宵赋。 (正韵)
    雨意生香阅读 5,016评论 66 119