前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[Leetcode][python]Merge k Sorted Lists/合并K个排序链表

[Leetcode][python]Merge k Sorted Lists/合并K个排序链表

作者头像
蛮三刀酱
发布2019-03-26 16:47:14
8420
发布2019-03-26 16:47:14
举报

题目大意

将k个排序好的链表合并成新的有序链表

解题思路

堆和分治法

代码

最小堆方法

用一个大小为K的最小堆(用优先队列+自定义降序实现)(优先队列就是大顶堆,队头元素最大,自定义为降序后,就变成小顶堆,队头元素最小),先把K个链表的头结点放入堆中,每次取堆顶元素,然后将堆顶元素所在链表的下一个结点加入堆中。

代码语言:javascript
复制
class Solution(object):
    def mergeKLists(self, lists):
        """
        :type lists: List[ListNode]
        :rtype: ListNode
        """
        heap = []
        for node in lists:
            if node: 
                heap.append((node.val, node))  # 堆中放入tuple:值,地址
        heapq.heapify(heap)  # 做成堆
        dummy = ListNode(0)
        curr = dummy

        while heap:
            pop = heapq.heappop(heap)  # 从堆中取最小的值
            curr.next = ListNode(pop[0])  # 将值放入
            curr = curr.next
            if pop[1].next:  # 如果该链表没结束
                heapq.heappush(heap, (pop[1].next.val, pop[1].next)) # 将该链表下个节点压入栈中
        return dummy.next

分治法

利用归并排序的思想,利用递归和分治法将链表数组划分成为越来越小的半链表数组,再对半链表数组排序,最后再用递归步骤将排好序的半链表数组合并成为越来越大的有序链表。

这里就需要用到分治法 Divide and Conquer Approach。简单来说就是不停的对半划分,比如k个链表先划分为合并两个k/2个链表的任务,再不停的往下划分,直到划分成只有一个或两个链表的任务,开始合并。举个例子来说比如合并6个链表,那么按照分治法,我们首先分别合并1和4,2和5,3和6。这样下一次只需合并3个链表,我们再合并1和3,最后和2合并就可以了。

总结

关于堆,理解的不是很透彻,可以参考以下两个文章继续学习: http://bubkoo.com/2014/01/14/sort-algorithm/heap-sort/ https://github.com/qiwsir/algorithm/blob/master/heapq.md

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年09月03日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目大意
  • 解题思路
  • 代码
    • 最小堆方法
    • 分治法
    • 总结
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档