python多个列表排序_python将多个已排序的列表逐个合并为一个大的排序列表

使用^{} module跟踪要从中选取下一个排序值的列表:import heapq

def merge(*iterables):

h = []

for it in map(iter, iterables):

try:

next = it.next

h.append([next(), next])

except StopIteration:

pass

heapq.heapify(h)

while True:

try:

while True:

v, next = s = h[0]

yield v

s[0] = next()

heapq._siftup(h, 0)

except StopIteration:

heapq.heappop(h)

except IndexError:

return

这会将所有列表推送到一个堆中,并按其下一个值进行排序。每次生成最小值时,都会用所使用的iterable中的下一个值更新堆,并再次对堆重新排序。在

这本质上保留了一个[next_value, iterable]列表的列表,这些列表按next_value有效地排序。在

用法:

^{pr2}$

或者big_list = list(merge(*sorted_lists))

创建一个新的大列表,将所有值排序,高效。在

这个确切的实现作为^{} function添加到heapq模块中,因此您只需执行以下操作:from heapq import merge

big_list = list(merge(*sorted_lists))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值