码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2018-11-26 02:33:29      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:列表   技术分享   val   over   log   poll   int   nod   sorted   

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

标签:列表   技术分享   val   over   log   poll   int   nod   sorted   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!