Общая техника, которую вы показываете, является самой эффективной и простой. Но вы делаете дополнительные задания, которые на самом деле не нужны. Ниже приведена небольшая оптимизация.
elements = []
k1, v1 = heapq.heappop(heap)
elements.append((k1,v1))
while(k1 == heap[0]):
k2, v2 = heapq.heappop(heap)
elements.append((k2,v2))
return elements
Чтобы быть в безопасности, вам, вероятно, следует добавить проверки, чтобы убедиться, что ваша куча не пуста. Проверка heap[0]
, когда в куче нет элементов, была бы плохой вещью, как и вызов heapq.heappop
, если куча пуста.