当前位置: 首页 > news >正文

leetcode热题100——day33

23. 合并 K 个升序链表

给你一个链表数组,每个链表都已经按升序排列。

请你将所有链表合并到一个升序链表中,返回合并后的链表。
在这里插入图片描述

AC代码

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode mergeKLists(ListNode[] lists) {// 判断边界if(lists == null || lists.length <= 0){return null;};// 初始化最小堆(优先级队列),升序排序PriorityQueue<ListNode> minHeap = new PriorityQueue<>((a,b) -> a.val - b.val);// 将列表中所有头节点加入堆for (ListNode head: lists) {// 跳过空节点if(head != null){minHeap.offer(head);};};// 创建新链表ListNode dummy = new ListNode(0);// 新链表当前节点ListNode cur = dummy;// 循环弹出堆顶点while(!minHeap.isEmpty()){// 堆中的当前节点,poll()获取的同时将此节点踢出ListNode smallest = minHeap.poll();cur.next = smallest; //合并链表cur = cur.next; //移动节点// 判断smallest是否还有下一个结点if(smallest.next != null){// 有就加入堆minHeap.offer(smallest.next);};};return dummy.next;}
}
http://www.dtcms.com/a/336326.html

相关文章:

  • 视频内容提取与AI总结:提升学习效率的实用方法
  • 【深度学习新浪潮】近三年图像处理领域无监督学习的研究进展一览
  • 科目二的四个电路
  • 《Vuejs设计与实现》第 14 章(内建组件和模块)
  • 概率dp|math
  • Android中切换语言的方法
  • 基于Netty的高并发WebSocket连接管理与性能优化实践指南
  • ReactNode 类型
  • 第12章《学以致用》—PowerShell 自学闭环与实战笔记
  • “让机器人更智慧 让具身体更智能”北京世界机器人大会行业洞察
  • Python 调试工具的高级用法
  • OJ目录饿
  • Python 基础语法(二)
  • Kubernetes存储迁移实战:从NFS到阿里云NAS完整指南
  • 【踩坑笔记】50系显卡适配的 PyTorch 安装
  • XF 306-2025 阻燃耐火电线电缆检测
  • JavaScript 性能优化实战:从评估到落地的全链路指南
  • Docker Compose 安装 Neo4j 的详细步骤
  • 福彩双色球第2025094期号码分析
  • Jenkins - CICD 注入环境变量避免明文密码暴露
  • 用MTEB对Embedding模型进行benchmark
  • Pell数列
  • 基本的设计原则
  • SONiC (4) - redis的介绍以及应用
  • 远程协作绘图:借助 cpolar 内网穿透服务访问 Excalidraw
  • 用PaddleDetection套件训练自己的数据集,PP-YOLO-SOD训练全流程
  • 领域快速入门过程记录之--电力网络
  • ROS常用命令手册
  • # C++ 中的 `string_view` 和 `span`:现代安全视图指南
  • GaussDB常用术语缩写及释义