python应用:Python3标准库,bisect维护有序列表

    作者:爱编程的小灰灰更新于: 2020-02-24 13:23:30

    大神带你学编程,欢迎选课

    1. bisect维护有序列表

      Python是一种解释型脚本语言,可以应用于以下领域:

      web和Internet开发

      科学计算和统计

      人工智能

      教育

      桌面界面开发

      软件开发

      后端开发

      网络爬虫

    bisect模块实现了一个算法来向列表中插入元素,同时仍保持列表有序。

    1.1 有序插入

    下面给出一个简单的例子,这里使用insort()按有序顺序向一个列表中插入元素。

    1. import bisect
    2. # A series of random numbers
    3. values =[14,85,77,26,50,45,66,79,10,3,84,77,1]
    4. print('New Pos Contents')
    5. print('--- --- --------')
    6. l =[]
    7. for i in values:
    8. position = bisect.bisect(l, i)
    9. bisect.insort(l, i)
    10. print('{:3} {:3}'.format(i, position), l)

    输出的第一列显示了新的随机数。第二轮显示了这个数将插入到列表的哪个位置。每一行余下的部分则是当前的有序列表。

    python应用:Python3标准库,bisect维护有序列表_python_编程语言_Python语言_课课家

    这是一个很简单的例子,实际上,对于此例处理的数据量来说,如果直接构建列表然后完成一次排序,可能速度更快。不过对于长列表而言,使用类似这样的一个插入排序算法可以大大节省时间和内存,尤其是比较两个列表成员的操作需要开销很大的计算时。 

     

    1.2 处理重复

    之前显示的结果集包括一个重复的值77。bisect模块提供了两种方法来处理重复。新值可以插入到原值的左边或右边。insort()函数实际上是insort_right()的别名,这个函数会在原值之后插入新值。相应的insort_left()函数则在原值之前插入新值。

    1. import bisect
    2. # A series of random numbers
    3. values =[14,85,77,26,50,45,66,79,10,3,84,77,1]
    4. print('New Pos Contents')
    5. print('--- --- --------')
    6. # Use bisect_left and insort_left.
    7. l =[]
    8. for i in values:
    9. position = bisect.bisect_left(l, i)
    10. bisect.insort_left(l, i)
    11. print('{:3} {:3}'.format(i, position), l)

    使用bisect_left()和insort_left()处理同样的数据时,结果是相同的有序列表,不过重复值插入的位置有所不同。

    Python是一种跨平台的计算机程序设计语言。是一种面向对象的动态类型语言,最初被设计用于编写自动化脚本(shell),随着版本的不断更新和语言新功能的添加,越多被用于独立的、大型项目的开发。

课课家教育

未登录