合并K个升序链表(题号23)

思路:使用优先级队列来处理,省去了自己比较节点大小的步骤

1.遍历lists,先将每个链表的头节点都放入优先级队列中,队列会自动比较大小

2.定义一个新的链表dummyNode

3.然后利用poll()方法获取到最小的节点minNode,加入到新链表的后面

4.如果minNode.next != null,再把minNode.next放到队列中

重复步骤三和步骤四,直到队列中没有任何元素。

java 复制代码
class Solution {
    public ListNode mergeKLists(ListNode[] lists) {
        Queue<ListNode> queue = new PriorityQueue<>((v1, v2) -> v1.val - v2.val);
        for (ListNode node: lists) {
            if (node != null) {
                queue.offer(node);
            }
        }
        ListNode dummyHead = new ListNode(0);
        ListNode tail = dummyHead;
        while (!queue.isEmpty()) {
            ListNode minNode = queue.poll();
            tail.next = minNode;
            tail = minNode;
            if (minNode.next != null) {
                queue.offer(minNode.next);
            }
        }
        return dummyHead.next;
    }
}

时间复杂度:O(kn*log(k))

空间复杂度:O(k)

看到此处即是情,别忘记点个赞哦。如果有其他问题,欢迎评论,共同探讨!!!

相关推荐
没书读了7 小时前
考研复习-数据结构-第六章-图
数据结构
future14129 小时前
C#进阶学习日记
数据结构·学习
Alfred king10 小时前
面试150 LRU缓存
链表·缓存·哈希表·lru·双向链表
ChoSeitaku12 小时前
NO.4数据结构数组和矩阵|一维数组|二维数组|对称矩阵|三角矩阵|三对角矩阵|稀疏矩阵
数据结构·人工智能·矩阵
Paper Clouds13 小时前
代码随想录|图论|15并查集理论基础
数据结构·算法·leetcode·深度优先·图论
Paper Clouds13 小时前
代码随想录|图论|14有向图的完全可达性
数据结构·算法·深度优先·图论·宽度优先
闻缺陷则喜何志丹15 小时前
【并集查找 虚拟节点】P1783 海滩防御|省选-
数据结构·c++·洛谷·并集查找·虚拟节点
GGBondlctrl15 小时前
【leetcode】字符串,链表的进位加法与乘法
算法·leetcode·链表·字符串相加·链表相加·字符串相乘
7 9716 小时前
C语言基础知识--柔性数组
数据结构·算法
打野二师兄16 小时前
LeetCode经典题解:21、合并两个有序链表
算法·leetcode·链表