bisect — 数组二分算法 — Python 文档
来自菜鸟教程
Python/docs/3.7/library/bisect
bisect — 数组二分算法
该模块支持按排序顺序维护列表,而不必在每次插入后对列表进行排序。 对于具有昂贵比较操作的长项目列表,这可能是对更常见方法的改进。 该模块称为 bisect,因为它使用基本的二分算法来完成其工作。 源代码作为算法的工作示例可能是最有用的(边界条件已经正确!)。
提供以下功能:
- bisect.bisect_left(a, x, lo=0, hi=len(a))
在 a 中找到 x 的插入点以保持排序顺序。 参数 lo 和 hi 可用于指定应考虑的列表子集; 默认情况下使用整个列表。 如果 x 已存在于 a 中,则插入点将位于任何现有条目之前(左侧)。 假设 a 已经排序,返回值适合用作
list.insert()
的第一个参数。返回的插入点 i 将数组 a 分成两半,以便左侧为
all(val < x for val in a[lo:i])
,右侧为all(val >= x for val in a[i:hi])
。
- bisect.bisect_right(a, x, lo=0, hi=len(a))
bisect.bisect(a, x, lo=0, hi=len(a)) 类似于 bisect_left(),但返回一个插入点,该插入点位于 a 中 x 的任何现有条目之后(右侧)。
返回的插入点 i 将数组 a 分成两半,以便左侧为
all(val <= x for val in a[lo:i])
,右侧为all(val > x for val in a[i:hi])
。
- bisect.insort_left(a, x, lo=0, hi=len(a))
- 按排序顺序将 x 插入 a。 这相当于
a.insert(bisect.bisect_left(a, x, lo, hi), x)
假设 a 已经排序。 请记住,O(log n) 搜索主要由缓慢的 O(n) 插入步骤决定。
- bisect.insort_right(a, x, lo=0, hi=len(a))
bisect.insort(a, x, lo=0, hi=len(a))
- 类似于 insort_left(),但在 x 的任何现有条目之后插入 x 到 a。
也可以看看
SortedCollection recipe 使用 bisect 构建一个功能齐全的集合类,具有直接的搜索方法和对键功能的支持。 这些键是预先计算好的,以便在搜索过程中保存对键功能的不必要调用。