合并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)

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

相关推荐
原来是猿26 分钟前
蓝桥备赛(13)- 链表和 list(上)
开发语言·数据结构·c++·算法·链表·list
总斯霖2 小时前
题解:士兵排列
数据结构·c++·算法
平谷一勺3 小时前
go切片定义和初始化
数据结构·golang·数组·切片
誓约酱3 小时前
(每日一题) 力扣 283 移动零
linux·c语言·数据结构·c++·算法·leetcode
橘子真甜~4 小时前
34.二叉树进阶3(平衡二叉搜索树 - AVL树及其旋转操作图解)
数据结构·c++·二叉搜索树·avl树·平衡搜索树
仟濹4 小时前
【算法 C/C++】一维前缀和
数据结构·c++·算法
tt5555555555554 小时前
每日一题——搜索二维矩阵
数据结构·算法·leetcode
阿瑾06185 小时前
【Python】基础语法(二)
数据结构·python
阿巴~阿巴~6 小时前
C/C++蓝桥杯算法真题打卡(Day4)
数据结构·c++·算法·蓝桥杯
gaohualan6 小时前
点云数据处理--splat转3dtiles
数据结构·python·算法·3d