From 09d9f86c7767bbd394591bc3b1c7d5025fc1f91b Mon Sep 17 00:00:00 2001 From: Skip Montanaro Date: Wed, 26 Jun 2002 05:07:28 +0000 Subject: [PATCH] add /F's PriorityQueue example --- Doc/lib/libbisect.tex | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/Doc/lib/libbisect.tex b/Doc/lib/libbisect.tex index 8c108a6a5e..32418914b8 100644 --- a/Doc/lib/libbisect.tex +++ b/Doc/lib/libbisect.tex @@ -61,7 +61,7 @@ The following functions are provided: \end{funcdesc} -\subsection{Example} +\subsection{Examples} \nodename{bisect-example} The \function{bisect()} function is generally useful for categorizing @@ -81,3 +81,21 @@ breakpoints: 85 and up is an `A', 75..84 is a `B', etc. >>> map(grade, [33, 99, 77, 44, 12, 88]) ['E', 'A', 'B', 'D', 'F', 'A'] \end{verbatim} + +The bisect module can be used with the Queue module to implement a priority +queue (example courtesy of Fredrik Lundh): \index{Priority Queue} + +\begin{verbatim} +import Queue, bisect + +class PriorityQueue(Queue.Queue): + def _put(self, item): + bisect.insort(self.queue, item) + +# usage +queue = PriorityQueue(0) +queue.put((2, "second")) +queue.put((1, "first")) +queue.put((3, "third")) +priority, value = queue.get() +\end{verbatim} -- 2.40.0