栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

[硕.Love Python] HeapSort(堆排序)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

[硕.Love Python] HeapSort(堆排序)

def adjust(a, root, n):
    k = a[root-1]
    c = root * 2

    while c <= n:
 if c + 1 <= n and a[c] > a[c-1]:
     c += 1

 if a[c-1] <= k:
     break

 a[c/2-1] = a[c-1]
 c *= 2

    a[c/2-1] = k

def heapSort(a):
    n = len(a)

    for i in xrange(n / 2, 0, -1):
 adjust(a, i, n)

    for i in xrange(n - 1, 0, -1):
 a[0], a[i] = a[i], a[0]
 adjust(a, 1, i)

if __name__ == '__main__':
    from random import shuffle

    data = range(100)
    shuffle(data)

    print data
    heapSort(data)
    print data
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/225955.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号