Python - 数据结构之堆
-
简述
堆是一种特殊的树结构,其中每个父节点都小于或等于其子节点。然后它被称为最小堆。如果每个父节点都大于或等于其子节点,则称为最大堆。实现优先级队列非常有用,其中具有较高权重的队列项目在处理中具有更高的优先级。在我们的网站上可以找到关于堆的详细讨论。如果您是堆数据结构的新手,请先学习它。在本章中,我们将看到使用 python 实现堆数据结构。 -
创建堆
使用 python 的内置库 heapq 创建一个堆。该库具有对堆数据结构进行各种操作的相关功能。下面是这些函数的列表。-
heapify− 此函数将常规列表转换为堆。在生成的堆中,最小的元素被推到索引位置 0。但其余数据元素不一定是排序的。
-
heappush− 该函数在不改变当前堆的情况下向堆中添加一个元素。
-
heappop− 该函数返回堆中最小的数据元素。
-
heapreplace− 该函数用函数中提供的新值替换最小的数据元素。
-
-
创建堆
通过简单地使用带有 heapify 函数的元素列表来创建堆。在下面的示例中,我们提供了一个元素列表,heapify 函数重新排列元素,将最小元素带到第一个位置。例子
import heapq H = [21,1,45,78,3,5] # Use heapify to rearrange the elements heapq.heapify(H) print(H)
输出
执行上述代码时,会产生以下结果 -[1, 3, 5, 78, 21, 45]
-
插入堆
将数据元素插入堆总是会在最后一个索引处添加元素。但是您可以再次应用 heapify 函数以将新添加的元素带到第一个索引,前提是它的值最小。在下面的示例中,我们插入数字 8。例子
import heapq H = [21,1,45,78,3,5] # Covert to a heap heapq.heapify(H) print(H) # Add element heapq.heappush(H,8) print(H)
输出
执行上述代码时,会产生以下结果 -[1, 3, 5, 78, 21, 45] [1, 3, 5, 78, 21, 45, 8]
-
从堆中移除
您可以使用此函数删除第一个索引处的元素。在下面的示例中,该函数将始终删除索引位置 1 处的元素。例子
import heapq H = [21,1,45,78,3,5] # Create the heap heapq.heapify(H) print(H) # Remove element from the heap heapq.heappop(H) print(H)
输出
执行上述代码时,会产生以下结果 -[1, 3, 5, 78, 21, 45] [3, 21, 5, 78, 45]
-
在堆中替换
堆替换函数总是删除堆中最小的元素,并将新的传入元素插入到某个不按任何顺序固定的位置。例子
import heapq H = [21,1,45,78,3,5] # Create the heap heapq.heapify(H) print(H) # Replace an element heapq.heapreplace(H,6) print(H)
输出
执行上述代码时,会产生以下结果 -[1, 3, 5, 78, 21, 45] [3, 6, 5, 78, 21, 45]