Python基础——bisect模块

文章目录

  • 简介
  • 使用

简介

这个模块对有序列表提供了支持,使得他们可以在插入新数据仍然保持有序。对于长列表,如果其包含元素的比较操作十分昂贵的话,这可以是对更常见方法的改进。这个模块叫做 bisect 因为其使用了基本的二分(bisection)算法。源代码也可以作为很棒的算法示例(边界判断也做好啦!)
bisect中有以下几个方法

  1. bisect
  2. bisect_left
  3. bisect_right
  4. insort
  5. insort_left
  6. insort_right

其中

  • bisect 就是调用的bisect_right

  • insort 就是调用 的insort_right

bisect 返回要插入元素在列表中的下标。假定列表是有序的。
bisect_left 与 bisect 类似,只不过其默认将元素插到左边,所以返回的是插入到左边的下标
bisect_right与 bisect_left 相反。
以上方法若列表无序,那么会返回插入到列表最后一个合适的位置。
insort 会在列表中插入元素到正确位置,假定列表有序。如果列表无序,那么会返回空。默认插入到右边。
insort_left 和insort_right 类似。

使用

bisect_left(a, x, lo=0, hi=None) ​
——其目的在于查找该数值将会插入的位置并返回,而不会插入。如果x存在在a中则返回x左边的位置

import bisect
li = [1, 23, 45, 12, 23, 42, 54, 123, 14, 52, 3]
li.sort()
print(li)
print(bisect.bisect_left(li, 3))
[1, 3, 12, 14, 23, 23, 42, 45, 52, 54, 123]
1

bisect_right(a, x, lo=0, hi=None) ​等同于 bisect(a, x, lo=0, hi=None)
——其目的在于查找该数值将会插入的位置并返回,而不会插入。如果x存在在a中则返回x右边的位置

import bisect

li = [1, 23, 45, 12, 23, 42, 54, 123, 14, 52, 3]
li.sort()
print(li)
print(bisect.bisect(li, 3))
[1, 3, 12, 14, 23, 23, 42, 45, 52, 54, 123]
2

insort_left(a, x, lo=0, hi=None) ​ ——
在列表a中插入元素x,并在排序后保持排序。如果x已经在a中,把它插入右x的左边。

mport bisect

li = [1, 23, 45, 12, 23, 42, 54, 123, 14, 52, 3]
li.sort()
print(li)
bisect.insort_left(li, 3.0)
print(li)
[1, 3, 12, 14, 23, 23, 42, 45, 52, 54, 123]
[1, 3.0, 3, 12, 14, 23, 23, 42, 45, 52, 54, 123]

insort_right(a, x, lo=0, hi=None) ​ ——
在列表a中插入元素x,并在排序后保持排序。如果x已经在a中,把它插入右x的右边。

import bisect

li = [1, 23, 45, 12, 23, 42, 54, 123, 14, 52, 3]
li.sort()
print(li)
bisect.insort(li, 3.0)
print(li)
[1, 3, 12, 14, 23, 23, 42, 45, 52, 54, 123]
[1, 3, 3.0, 12, 14, 23, 23, 42, 45, 52, 54, 123

]

你可能感兴趣的:(#,Python基础,python,开发语言,后端)