""" Heap queue algorithm. MicroPython module: https://docs.micropython.org/en/v1.26.0/library/heapq.html CPython module: :mod:`python:heapq` https://docs.python.org/3/library/heapq.html . This module implements the `min heap queue algorithm `_. A heap queue is essentially a list that has its elements stored in such a way that the first item of the list is always the smallest. --- Module: 'heapq' on micropython-v1.26.0-rp2-RPI_PICO """ # MCU: {'mpy': 'v6.3', 'build': '', 'ver': '1.26.0', 'arch': 'armv6m', 'version': '1.26.0', 'port': 'rp2', 'board': 'RPI_PICO', 'family': 'micropython', 'board_id': 'RPI_PICO', 'variant': '', 'cpu': 'RP2040'} # Stubber: v1.26.0 from __future__ import annotations from _typeshed import Incomplete from typing import Any from typing_extensions import Awaitable, TypeAlias, TypeVar _T = TypeVar("_T") def heappop(heap: list[_T], /) -> _T: """ Pop the first item from the ``heap``, and return it. Raise ``IndexError`` if ``heap`` is empty. The returned item will be the smallest item in the ``heap``. """ ... def heappush(heap: list[_T], item: _T, /) -> None: """ Push the ``item`` onto the ``heap``. """ ... def heapify(x: list[Any], /) -> None: """ Convert the list ``x`` into a heap. This is an in-place operation. """ ...