• python之插入排序


    插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据,算法适用于少量数据的排序,时间复杂度为O(n^2)。是稳定的排序方法。插入算法把要排序的数组分成两部分:第一部分包含了这个数组的所有元素,但将最后一个元素除外(让数组多一个空间才有插入的位置),而第二部分就只包含这一个元素(即待插入元素)。在第一部分排序完成后,再将这个最后元素插入到已排好序的第一部分中。
    #encoding=utf-8
    def insertSort(listx):
    count=len(listx)
    for i in range(1,count):#第一个元素本身有序,从第二个开始
    key=listx[i]
    j=i-1#当前元素前面一个元素
    while j>=0:
    if listx[j]>key:
    listx[j],listx[j+1]=listx[j+1],listx[j]
    j-=1#交换完位置之后再次比较
    else:
    break
    return listx

    if __name__=="__main__":
    print (insertSort([3,1,6,7,45,21]))

    时间复杂度:
    最好情况:O(n)
    最坏情况:O(n^2)

  • 相关阅读:
    既然选择了远方,就只顾风雨兼程!
    slots
    面向对象
    模块和作用域
    偏函数
    python中decorator
    返回函数
    filter, sort
    map/reduce
    开发步骤
  • 原文地址:https://www.cnblogs.com/tom-gao/p/7902611.html
Copyright © 2020-2023  润新知