堆&优先队列

堆:完全二叉树,自上而下,自左向右添加元素,除了最后一层其他层全为满的,最后一层的节点都靠左对齐。每个节点k都有两个子节点2k+1,2k+2.

小根堆:每个节点小于等于子节点。

大根堆:每个节点大于等于子节点。

python内置库:import heapq

定义一个数组a=list(map(int,input().split()))

1.将数组a转化为堆(默认为小根堆,如果想变为大根堆那么把元素全加一个负号。)

heapq.heapify(a)

2.最小堆a中添加元素x

heapq.heappush(a,x)

3.弹出并返回最小元素

heapq.heappop(a)

4.弹出并返回最小元素同时添加x

heapq.heapreplace(a,x)

优先队列:

一种抽象的数据类型,依照其它的数据结构来实现对的,非严格说优先队列就是堆,python中优先队列底层依照堆来实现,即对堆进行了封装。

from queue import PriorityQueue

pd=PriorityQueue() ,(不能将pd转化为list,报错)

pd.put(x) 向优先队列pd中添加元素x,x可以是二维元组。相当于堆中的(heapq.heappush(a,x))

pd.get()取出优先队列中最小的元素(取出优先队列中优先级最高的元素,默认为小根堆,如果想变为大根堆则变为相应的负数)相当于堆中的heapq.heappop(a)

pd.queue[0]获取优先队列中的最小元素(不删除)

  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值