python之bisect模块

来源:互联网 发布:获取数组赋值的长度 编辑:程序博客网 时间:2024/04/29 18:38

 今天看一致性hash算法的python实现用到了bisect函数,在网上找到下面这篇文章总结的很好 记录一下

       先看看模块的结构:

      

       前面五个属性大家感兴趣可以打出来看看数值,这里就不介绍了。

       先说明的是,使用这个模块的函数前先确保操作的列表是已排序的。

      

       先看看 insort  函数:

       

       其插入的结果是不会影响原有的排序。

       再看看 bisect  函数:

       

       其目的在于查找该数值将会插入的位置并返回,而不会插入。

       接着看 bisect_left 和 bisect_right 函数,该函数用入处理将会插入重复数值的情况,返回将会插入的位置:

       

       其对应的插入函数是 insort_left  和 insort_right :

       

       可见,单纯看其结果的话,两个函数的操作结果是一样的,其实插入的位置不同而已。

0 0