首页 > 编程语言 > 详细

合并k个排序的列表 Merge k Sorted Lists

时间:2018-11-26 00:46:26      阅读:167      评论:0      收藏:0      [点我收藏+]

2018-11-25 22:58:52

问题描述:

技术分享图片

问题求解:

本题可以使用优先队列高效的进行求解,整体的时间复杂度为O(nlogk)。

    public ListNode mergeKLists(ListNode[] lists) {
        ListNode dummy = new ListNode(-1);
        ListNode cur = dummy;
        PriorityQueue<ListNode> pq = new PriorityQueue<>(new Comparator<ListNode>() {
            @Override
            public int compare(ListNode o1, ListNode o2) {
                return o1.val - o2.val;
            }
        });
        for (ListNode ln : lists) if (ln != null) pq.add(ln);
        while (!pq.isEmpty()) {
            cur.next = pq.poll();
            cur = cur.next;
            if (cur.next != null) pq.add(cur.next);
        }
        return dummy.next;
    }

 

合并k个排序的列表 Merge k Sorted Lists

原文:https://www.cnblogs.com/TIMHY/p/10018016.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!