微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么 heappush 需要 3 个参数?

如何解决为什么 heappush 需要 3 个参数?

为什么 heappush 采用 3 个参数 arr[i].data、i 和 arr[i]。 为什么将 i 作为参数 它通常需要一一参数 这是合并k个排序链表的代码

def mergeKLists(arr,K):
# code here
# return head of merged list
    heap = []
    head = tail = Node(0)
    for i in range(K):
        heapq.heappush(heap,(arr[i].data,i,arr[i]))

    while heap:
        node = heapq.heappop(heap)
        node = node[2]
        tail.next = node
        tail = tail.next
        if node.next:
            i += 1
            heapq.heappush(heap,(node.next.data,node.next))
    return head.next

解决方法

它没有。在您的代码中,您将一个元组推送到堆中,但这不是必需的。例如:

import heapq

h = [1,2,3,4]
heapq.heapify(h)

v = heapq.heappop(h) # Returns 1

heapq.heappush(h,6) # Now h = [2,4,6]
,

实际上当元组作为输入时 比较器函数将采用第一个属性进行比较,如果它们相同,它将转到下一个属性,依此类推 如果两个值相同,它将抛出“TypeError: unorderable types: Node() i

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。