zoukankan      html  css  js  c++  java
  • 算法----堆的简单介绍

    一、堆的分类

    大根堆:一棵完全二叉树,满足任一节点都比其孩子节点大
    小根堆:一棵完全二叉树,满足任一节点都比其孩子节点小

    二、堆的向下调整性质

    前提:节点的左右子树都是堆,但是自身不是堆

    三、堆排序-----内置模块

    优先队列:一些元素的集合,POP操作每次执行都会从优先队列中弹出最大(或最小)的元素。
    堆——优先队列

    Python内置模块——heapq
    heapify(x)  #将list类型转化为heap, 在线性时间内, 重新排列列表
    heappush(heap, item)
    heappop(heap)

    利用heapq模块实现堆排序

    复制代码
    #!usr/bin/env python
    # -*- coding:utf-8 -*-
    import heapq
    import random
    def heapqsort(li):
        h = []
        for v in li:
            heapq.heappush(h,v)   #向h列表里面添加要进行排序的列表
        return [heapq.heappop(h) for i in range(len(h))]  #返回排序好的结果
    
    li = list(range(10))
    random.shuffle(li)
    print(li)   #[6, 0, 4, 1, 8, 5, 3, 7, 2, 9]
    s = heapqsort(li)
    print(s)   #[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
    复制代码
  • 相关阅读:
    1-1-折纸问题
    调整数组顺序使奇数位于偶数前面
    在O(1)时间删除链表结点
    打印1到最大的n位数
    数值的整数次方
    二进制中1的个数
    变态跳台阶
    旋转数组的最小数字
    用两个栈实现队列
    Swift学习笔记(5):集合类型
  • 原文地址:https://www.cnblogs.com/TheLand/p/9250547.html
Copyright © 2011-2022 走看看