python数据结构-堆

一种特殊的树结构:每个父节点小于或者等于其子结点,称为最小堆
如果每个父节点大于等于子结点,称为最大堆
实施优先级 队列 是非常有用的
在该队列中,具有较高权重的队列项目在处理中具有更高的优先级
堆是通过使用python内建的名为heapq的库创建的
heapify - 此函数将常规列表转换为堆。在结果堆中,最小的元素被推到索引位置0.但其余的数据元素不一定被排序。
heappush - 这个函数在堆中添加一个元素而不改变当前堆。
heappop - 该函数返回堆中最小的数据元素。
heapreplace - 该函数用函数中提供的新值替换最小的数据元素。

import heapq
list=[2,3,4,5,65,23,56]
#使用heapify创建堆
heapq.heapify(list) #建堆
print(type(list))
print(list)

#插入堆
heapq.heappush(list,12) #两个参数:第一个是原堆,第二个是插入值
print('插入堆中\n',list)

#从堆中移除(堆中第一个元素)
heapq.heappop(list)
print('删除第一个元素\n',list)

#替换replace
#heapreplace函数总是删除堆中最小的元素
# 并在未被任何顺序修复的地方插入新的传入元素。
heapq.heapreplace(list,0)
print(type(list))
print('替换后\n',list)
<class 'list'>
[2, 3, 4, 5, 65, 23, 56]
插入堆中
 [2, 3, 4, 5, 65, 23, 56, 12]
删除第一个元素
 [3, 5, 4, 12, 65, 23, 56]
<class 'list'>
替换后
 [0, 5, 4, 12, 65, 23, 56]
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值