欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

一个有趣的python排序模块:bisect

程序员文章站 2022-05-14 10:41:42
...
今天同事说到了一个python的排序模块bisect,觉得挺有趣的,跟大家分享分享。

先看看模块的结构:

一个有趣的python排序模块:bisect

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

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

一个有趣的python排序模块:bisect

先看看 insort 函数:

一个有趣的python排序模块:bisect

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

再看看 bisect 函数:

一个有趣的python排序模块:bisect

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

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

一个有趣的python排序模块:bisect

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

一个有趣的python排序模块:bisect

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

相关标签: bisect