Add item
[pytest.git] / Lib / bisect.py
blob152f6c7854f829ad3eca53dadb6d383220e1e1a4
1 """Bisection algorithms."""
3 def insort_right(a, x, lo=0, hi=None):
4 """Insert item x in list a, and keep it sorted assuming a is sorted.
6 If x is already in a, insert it to the right of the rightmost x.
8 Optional args lo (default 0) and hi (default len(a)) bound the
9 slice of a to be searched.
10 """
12 if hi is None:
13 hi = len(a)
14 while lo < hi:
15 mid = (lo+hi)//2
16 if x < a[mid]: hi = mid
17 else: lo = mid+1
18 a.insert(lo, x)
20 insort = insort_right # backward compatibility
22 def bisect_right(a, x, lo=0, hi=None):
23 """Return the index where to insert item x in list a, assuming a is sorted.
25 The return value i is such that all e in a[:i] have e <= x, and all e in
26 a[i:] have e > x. So if x already appears in the list, i points just
27 beyond the rightmost x already there.
29 Optional args lo (default 0) and hi (default len(a)) bound the
30 slice of a to be searched.
31 """
33 if hi is None:
34 hi = len(a)
35 while lo < hi:
36 mid = (lo+hi)//2
37 if x < a[mid]: hi = mid
38 else: lo = mid+1
39 return lo
41 bisect = bisect_right # backward compatibility
43 def insort_left(a, x, lo=0, hi=None):
44 """Insert item x in list a, and keep it sorted assuming a is sorted.
46 If x is already in a, insert it to the left of the leftmost x.
48 Optional args lo (default 0) and hi (default len(a)) bound the
49 slice of a to be searched.
50 """
52 if hi is None:
53 hi = len(a)
54 while lo < hi:
55 mid = (lo+hi)//2
56 if a[mid] < x: lo = mid+1
57 else: hi = mid
58 a.insert(lo, x)
61 def bisect_left(a, x, lo=0, hi=None):
62 """Return the index where to insert item x in list a, assuming a is sorted.
64 The return value i is such that all e in a[:i] have e < x, and all e in
65 a[i:] have e >= x. So if x already appears in the list, i points just
66 before the leftmost x already there.
68 Optional args lo (default 0) and hi (default len(a)) bound the
69 slice of a to be searched.
70 """
72 if hi is None:
73 hi = len(a)
74 while lo < hi:
75 mid = (lo+hi)//2
76 if a[mid] < x: lo = mid+1
77 else: hi = mid
78 return lo
80 # Overwrite above definitions with a fast C implementation
81 try:
82 from _bisect import bisect_right, bisect_left, insort_left, insort_right, insort, bisect
83 except ImportError:
84 pass