LeetCode hot100-34-G

23. 合并 K 个升序链表

请你将所有链表合并到一个升序链表中,返回合并后的链表。

这题没做出来
其实有个很自然的想法应该想到的,也就是官方解法一
两个升序链表合并这个应该会。多个的困难就是没办法分别用指针指向每个链表头,然后比较大小。其实不需要这样做,就用结果链表和每一个单独的链表合并就好了。写循环即可

class Solution {
    public ListNode mergeKLists(ListNode[] lists) {
        ListNode ans = null;
        for (int i = 0; i < lists.length; ++i) {
            ans = mergeTwoLists(ans, lists[i]);
        }
        return ans;
    }

    public ListNode mergeTwoLists(ListNode a, ListNode b) {
        if (a == null || b == null) {
            return a != null ? a : b;
        }
        ListNode head = new ListNode(0);
        ListNode tail = head, aPtr = a, bPtr = b;
        while (aPtr != null && bPtr != null) {
            if (aPtr.val  bPtr.val) {
                tail.next = aPtr;
                aPtr = aPtr.next;
            } else {
                tail.next = bPtr;
                bPtr = bPtr.next;
            }
            tail = tail.next;
        }
        tail.next = (aPtr != null ? aPtr : bPtr);
        return head.next;
    }
}

作者:力扣官方题解
链接:https://leetcode.cn/problems/merge-k-sorted-lists/solutions/219756/he-bing-kge-pai-xu-lian-biao-by-leetcode-solutio-2/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

在评论区看到一个不错的解法
https://leetcode.cn/problems/merge-k-sorted-lists/description/
评论里昵称为 执剑 的用户 2019.04.12的答案

定义最小堆优先队列,把每个链表的头结点都放进去,然后出队当前优先队列中最小的,挂上链表,然后让出队的那个节点的下一个入队,再出队当前优先队列中最小的,直到优先队列为空。

class Solution {
    public ListNode mergeKLists(ListNode[] lists) {

        if (lists.length == 0) {
            return null;
        }

        ListNode dummyHead = new ListNode(0);
        ListNode curr = dummyHead;
        PriorityQueue<ListNode> pq = new PriorityQueue<>(new Comparator<ListNode>() {
            @Override
            public int compare(ListNode o1, ListNode o2) {
                return o1.val - o2.val;
            }
        });

        for (ListNode list : lists) {
            if (list == null) {
                continue;
            }
            pq.add(list);
        }

        while (!pq.isEmpty()) {
            ListNode nextNode = pq.poll();
            curr.next = nextNode;
            curr = curr.next;
            if (nextNode.next != null) {
                pq.add(nextNode.next);
            }
        }
        return dummyHead.next;
    }
}

相关推荐

  1. LeetCodehot100

    2024-05-11 14:12:03       57 阅读
  2. LeetCode hot100-34-G

    2024-05-11 14:12:03       33 阅读
  3. LeetCode hot100-31-G

    2024-05-11 14:12:03       34 阅读
  4. 一个月速刷leetcodeHOT100 day02

    2024-05-11 14:12:03       37 阅读
  5. 一个月速刷leetcodeHOT100 day 01

    2024-05-11 14:12:03       94 阅读
  6. 一个月速刷leetcodeHOT100 day03

    2024-05-11 14:12:03       33 阅读
  7. 一个月速刷leetcodeHOT100 day08 两道DP题 一道子串

    2024-05-11 14:12:03       35 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-11 14:12:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-11 14:12:03       106 阅读
  3. 在Django里面运行非项目文件

    2024-05-11 14:12:03       87 阅读
  4. Python语言-面向对象

    2024-05-11 14:12:03       96 阅读

热门阅读

  1. 如何在本地调试THUDM/chatglm2-6b大模型

    2024-05-11 14:12:03       36 阅读
  2. 保研机试之【构造二叉树】

    2024-05-11 14:12:03       36 阅读
  3. 软件测试应用技术--架构相关的注意事项

    2024-05-11 14:12:03       34 阅读
  4. 25、Flink 支持的数据类型及序列化详解

    2024-05-11 14:12:03       26 阅读
  5. 【图像超分】论文精读:Deep Image Prior(DIP)

    2024-05-11 14:12:03       36 阅读
  6. 【QEMU系统分析之实例篇(二十七)】

    2024-05-11 14:12:03       28 阅读
  7. MySQL变量的定义与使用(一)

    2024-05-11 14:12:03       33 阅读
  8. leetcode21-Merge Two Sorted Lists

    2024-05-11 14:12:03       34 阅读
  9. 单例模式(Singleton Pattern)

    2024-05-11 14:12:03       38 阅读
  10. Flask-Login 实现用户认证

    2024-05-11 14:12:03       30 阅读
  11. 投影与降维

    2024-05-11 14:12:03       34 阅读
  12. npm入门介绍

    2024-05-11 14:12:03       33 阅读