zoukankan      html  css  js  c++  java
  • 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)

  • 相关阅读:
    全表扫描
    服务器信息表
    事务的丢失更新
    oracle core 概述
    oracle命中率模型计算
    性能量化之cpu
    一个sql导致temp表空间爆掉
    oracle稳定执行计划1
    oracle热点表online rename
    oracle构建一致性读
  • 原文地址:https://www.cnblogs.com/tom-gao/p/7902611.html
Copyright © 2011-2022 走看看