Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
9092d20e
Commit
9092d20e
authored
Sep 01, 2010
by
Raymond Hettinger
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Clean-up bisect docs
parent
2f40d7d4
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
62 additions
and
60 deletions
+62
-60
Doc/library/bisect.rst
Doc/library/bisect.rst
+62
-60
No files found.
Doc/library/bisect.rst
View file @
9092d20e
...
@@ -4,6 +4,7 @@
...
@@ -4,6 +4,7 @@
.. module:: bisect
.. module:: bisect
:synopsis: Array bisection algorithms for binary searching.
:synopsis: Array bisection algorithms for binary searching.
.. sectionauthor:: Fred L. Drake, Jr. <fdrake@acm.org>
.. sectionauthor:: Fred L. Drake, Jr. <fdrake@acm.org>
.. sectionauthor:: Raymond Hettinger <python at rcn.com>
.. example based on the PyModules FAQ entry by Aaron Watters <arw@pythonpros.com>
.. example based on the PyModules FAQ entry by Aaron Watters <arw@pythonpros.com>
This module provides support for maintaining a list in sorted order without
This module provides support for maintaining a list in sorted order without
...
@@ -18,13 +19,16 @@ The following functions are provided:
...
@@ -18,13 +19,16 @@ The following functions are provided:
.. function:: bisect_left(a, x, lo=0, hi=len(a))
.. function:: bisect_left(a, x, lo=0, hi=len(a))
Locate the
proper
insertion point for *x* in *a* to maintain sorted order.
Locate the insertion point for *x* in *a* to maintain sorted order.
The parameters *lo* and *hi* may be used to specify a subset of the list
The parameters *lo* and *hi* may be used to specify a subset of the list
which should be considered; by default the entire list is used. If *x* is
which should be considered; by default the entire list is used. If *x* is
already present in *a*, the insertion point will be before (to the left of)
already present in *a*, the insertion point will be before (to the left of)
any existing entries. The return value is suitable for use as the first
any existing entries. The return value is suitable for use as the first
parameter to ``list.insert()``
. This assumes
that *a* is already sorted.
parameter to ``list.insert()``
assuming
that *a* is already sorted.
The returned insertion point *i* partitions the array *a* into two halves so
that ``all(val < x for val in a[lo:i])`` for the left side and
``all(val >= x for val in a[i:hi])`` for the right side.
.. function:: bisect_right(a, x, lo=0, hi=len(a))
.. function:: bisect_right(a, x, lo=0, hi=len(a))
bisect(a, x, lo=0, hi=len(a))
bisect(a, x, lo=0, hi=len(a))
...
@@ -32,16 +36,16 @@ The following functions are provided:
...
@@ -32,16 +36,16 @@ The following functions are provided:
Similar to :func:`bisect_left`, but returns an insertion point which comes
Similar to :func:`bisect_left`, but returns an insertion point which comes
after (to the right of) any existing entries of *x* in *a*.
after (to the right of) any existing entries of *x* in *a*.
The returned insertion point *i* partitions the array *a* into two halves so
that ``all(val <= x for val in a[lo:i])`` for the left side and
``all(val > x for val in a[i:hi])`` for the right side.
.. function:: insort_left(a, x, lo=0, hi=len(a))
.. function:: insort_left(a, x, lo=0, hi=len(a))
Insert *x* in *a* in sorted order. This is equivalent to
Insert *x* in *a* in sorted order. This is equivalent to
``a.insert(bisect.bisect_left(a, x, lo, hi), x)``. This assumes that *a* is
``a.insert(bisect.bisect_left(a, x, lo, hi), x)`` assuming that *a* is
already sorted.
already sorted. Keep in mind that the O(log n) search is dominated by
the slow O(n) insertion step.
Also note that while the fast search step is O(log n), the slower insertion
step is O(n), so the overall operation is slow.
.. function:: insort_right(a, x, lo=0, hi=len(a))
.. function:: insort_right(a, x, lo=0, hi=len(a))
insort(a, x, lo=0, hi=len(a))
insort(a, x, lo=0, hi=len(a))
...
@@ -49,71 +53,75 @@ The following functions are provided:
...
@@ -49,71 +53,75 @@ The following functions are provided:
Similar to :func:`insort_left`, but inserting *x* in *a* after any existing
Similar to :func:`insort_left`, but inserting *x* in *a* after any existing
entries of *x*.
entries of *x*.
Also note that while the fast search step is O(log n), the slower insertion
.. seealso::
step is O(n), so the overall operation is slow.
`SortedCollection recipe
<http://code.activestate.com/recipes/577197-sortedcollection/>`_ that uses
bisect to build a full-featured collection class with straight-forward search
methods and support for a key-function. The keys are precomputed to save
unnecessary calls to the key function during searches.
Searching Sorted Lists
Searching Sorted Lists
----------------------
----------------------
The above :func:`bisect` functions are useful for finding insertion points
,
but
The above :func:`bisect` functions are useful for finding insertion points but
can be tricky or awkward to use for common searching tasks. The following
thre
e
can be tricky or awkward to use for common searching tasks. The following
fiv
e
functions show how to transform them into the standard lookups for sorted
functions show how to transform them into the standard lookups for sorted
lists::
lists::
def find(a, key):
def index(a, x):
'''Find leftmost item exact equal to the key.
'Locate the leftmost value exactly equal to x'
Raise ValueError if no such item exists.
i = bisect_left(a, x)
if i != len(a) and a[i] == x:
'''
return i
i = bisect_left(a, key)
raise ValueError
if i < len(a) and a[i] == key:
def find_lt(a, x):
'Find rightmost value less than x'
i = bisect_left(a, x)
if i:
return a[i-1]
raise ValueError
def find_le(a, x):
'Find rightmost value less than or equal to x'
i = bisect_right(a, x)
if i:
return a[i-1]
raise ValueError
def find_gt(a, x):
'Find leftmost value greater than x'
i = bisect_right(a, x)
if i != len(a):
return a[i]
return a[i]
raise ValueError('No item found with key equal to: %r' % (key,))
raise ValueError
def find_le(a, key):
'''Find largest item less-than or equal to key.
Raise ValueError if no such item exists.
If multiple keys are equal, return the leftmost.
'''
def find_ge(a, x):
i = bisect_left(a, key)
'Find leftmost item greater than or equal to x'
if i < len(a) and a[i] == key:
i = bisect_left(a, x)
if i != len(a):
return a[i]
return a[i]
if i == 0:
raise ValueError
raise ValueError('No item found with key at or below: %r' % (key,))
return a[i-1]
def find_ge(a, key):
'''Find smallest item greater-than or equal to key.
Raise ValueError if no such item exists.
If multiple keys are equal, return the leftmost.
'''
i = bisect_left(a, key)
if i == len(a):
raise ValueError('No item found with key at or above: %r' % (key,))
return a[i]
Other Examples
Other Examples
--------------
--------------
.. _bisect-example:
.. _bisect-example:
The :func:`bisect` function
is generally useful for categorizing numeric data.
The :func:`bisect` function
can be useful for numeric table lookups. This
This example uses :func:`bisect` to look up a letter grade for an exam total
example uses :func:`bisect` to look up a letter grade for an exam score (say)
(say) based on a set of ordered numeric breakpoints: 85 and up is an 'A', 75..84
based on a set of ordered numeric breakpoints: 90 and up is an 'A', 80 to 89 is
is a 'B', etc.
a 'B', and so on::
>>> grades = "FEDCBA"
>>> def grade(score, breakpoints=[60, 70, 80, 90], grades='FDCBA'):
>>> breakpoints = [30, 44, 66, 75, 85]
... i = bisect(breakpoints, score)
>>> from bisect import bisect
... return grades[i]
>>> def grade(total):
... return grades[bisect(breakpoints, total)]
...
...
>>> grade(66)
>>> [grade(score) for score in [33, 99, 77, 70, 89, 90, 100]]
'C'
['F', 'A', 'C', 'C', 'B', 'A', 'A']
>>> map(grade, [33, 99, 77, 44, 12, 88])
['E', 'A', 'B', 'D', 'F', 'A']
Unlike the :func:`sorted` function, it does not make sense for the :func:`bisect`
Unlike the :func:`sorted` function, it does not make sense for the :func:`bisect`
functions to have *key* or *reversed* arguments because that would lead to an
functions to have *key* or *reversed* arguments because that would lead to an
...
@@ -135,9 +143,3 @@ of the record in question::
...
@@ -135,9 +143,3 @@ of the record in question::
>>> data[bisect_left(keys, 8)]
>>> data[bisect_left(keys, 8)]
('yellow', 8)
('yellow', 8)
.. seealso::
`SortedCollection recipe
<http://code.activestate.com/recipes/577197-sortedcollection/>`_ that
encapsulates precomputed keys, allowing straight-forward insertion and
searching using a *key* function.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment