Commit 74108dda authored by Eli Bendersky's avatar Eli Bendersky

Issue #23549: Clarify confusion in heapq doc - accessing the mininmal element

The current documentation only mentions heap[0] as the smallest element in the
beginning, and not in any of the methods' docs. There's no method to access the
minimal element without popping it, and the documentation of nsmallest is
confusing because it may suggest that min() is the way to go for n==1.
default
parent e2301987
...@@ -49,7 +49,8 @@ The following functions are provided: ...@@ -49,7 +49,8 @@ The following functions are provided:
.. function:: heappop(heap) .. function:: heappop(heap)
Pop and return the smallest item from the *heap*, maintaining the heap Pop and return the smallest item from the *heap*, maintaining the heap
invariant. If the heap is empty, :exc:`IndexError` is raised. invariant. If the heap is empty, :exc:`IndexError` is raised. To access the
smallest item without popping it, use ``heap[0]``.
.. function:: heappushpop(heap, item) .. function:: heappushpop(heap, item)
...@@ -125,7 +126,8 @@ The module also offers three general purpose functions based on heaps. ...@@ -125,7 +126,8 @@ The module also offers three general purpose functions based on heaps.
The latter two functions perform best for smaller values of *n*. For larger The latter two functions perform best for smaller values of *n*. For larger
values, it is more efficient to use the :func:`sorted` function. Also, when values, it is more efficient to use the :func:`sorted` function. Also, when
``n==1``, it is more efficient to use the built-in :func:`min` and :func:`max` ``n==1``, it is more efficient to use the built-in :func:`min` and :func:`max`
functions. functions. If repeated usage of these functions is required, consider turning
the iterable into an actual heap.
Basic Examples Basic Examples
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment