【算法五十八】23. 合并 K 个升序链表

23. 合并 K 个升序链表 - 力扣(LeetCode)

小根堆:

java 复制代码
class Solution {
    public ListNode mergeKLists(ListNode[] lists) {
        //小根堆
        PriorityQueue<ListNode> heap = new PriorityQueue<>(
            (a,b) -> Integer.compare(a.val, b.val)
        );
        //答案
        ListNode dummy = new ListNode();
        ListNode cur = dummy;
        //把每个头节点加入堆
        for(ListNode node:lists){
            if(node != null){
                heap.offer(node);
            }
        }
        //把堆里最小的加入链表
        while(!heap.isEmpty()){
            ListNode mini = heap.poll();
            cur.next = mini;
            cur = cur.next;
            if(mini.next != null){
                heap.offer(mini.next);
            }
        }
        return dummy.next;
    }
}

N是节点总数,K是堆大小

时间复杂度:Nlog(K)

空间复杂度:O(K)

相关推荐
思茂信息1 小时前
CST软件基于液态金属开关的方向图可重构天线
服务器·算法·重构·cst·仿真软件·电磁仿真
月疯2 小时前
PPG研究中暑的算法记录
算法
春日见2 小时前
vscode的AI编程插件推荐:
大数据·ide·vscode·算法·机器学习·编辑器·ai编程
blxr_2 小时前
力扣hot100路径总和Ⅲhttps://leetcode.cn/problems/path-sum-iii/
算法·leetcode·职场和发展
noipp2 小时前
【无标题】
c语言·数据结构·c++·算法
渡众机器人3 小时前
第八届全球校园人工智能算法精英大赛-算法应用赛-渡众机器人智能体对抗挑战赛规则
人工智能·算法·机器人·自动驾驶·自主导航·对抗赛
郝学胜-神的一滴3 小时前
完全二叉树与堆底层原理深度剖析 | 手写C++大顶堆实现
java·开发语言·数据结构·c++·python·算法
青山木3 小时前
Hot 100 --- 缺失的第一个正数
算法·leetcode·哈希算法
农民小飞侠3 小时前
[leetcode] 165. Compare Version Numbers
java·算法·leetcode