2.5 bisect:维护有序列表
bisect模块实现了一个算法来向列表中插入元素,同时仍保持列表有序。
2.5.1 有序插入
下面给出一个简单的例子,这里使用insort()按有序顺序向一个列表中插入元素。
import bisect
# A series of random numbers
values = [14,85,77,26,50,45,66,79,10,3,84,77,1]
print('New Pos Contents')
print('--- --- --------')
l = []
for i in values:
position = bisect.bisect(l,i)
bisect.insort(l,i)
print('{:3} {:3}'.format(i,position),l)
输出的第一列显示了新随机数。第二列显示了这个数将插入到列表的哪个位置。每一行余下的部分则是当前的有序列表。
这是一个很简单的例子,实际上,对于此例处理的数据量来说,如果直接构建列表然后完成一次排序,可能速度更快。不过对于长列表而言,使用类似这样的一个插入排序算法可以大大节省时间和内存,尤其是比较两个列表成员的操作需要开销很大的计算时。
运行结果: