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

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

题目链接

23.合并K个升序链表

class Solution {public ListNode mergeKLists(ListNode[] lists) {if (lists.length == 0)return null;if (lists.length == 1)return lists[0];int mid = lists.length / 2;ListNode[] left = Arrays.copyOfRange(lists, 0, mid);ListNode[] right = Arrays.copyOfRange(lists, mid, lists.length);ListNode l1 = mergeKLists(left);ListNode l2 = mergeKLists(right);return mergeTwo(l1, l2);}public ListNode mergeTwo(ListNode l1, ListNode l2) {ListNode dummy = new ListNode(0);ListNode cur = dummy;while (l1 != null && l2 != null) {if (l1.val < l2.val) {ListNode temp = l1.next;l1.next = null;cur.next = l1;l1 = temp;} else {ListNode temp = l2.next;l2.next = null;cur.next = l2;l2 = temp;}cur = cur.next;}if (l1 != null) {cur.next = l1;}if (l2 != null) {cur.next = l2;}return dummy.next;}
}

小结:用递归分治的思想把两个链表的合并拓展到多个,首先把链表数组划分为左右两部分,分别递归进行合并,之后把合并完成的两个数组进行合并。

http://www.dtcms.com/a/281970.html

相关文章:

  • Linux 驱动中 Timer / Tasklet / Workqueue 的作用与对比
  • 查看.bin二进制文件的方式(HxD十六进制编辑器的安装)
  • 电路仿真——精密半波整流电路
  • 133. Java 泛型 - 目标类型与方法参数:重载解析与类型推导
  • 网络编程(数据库)
  • 在虚拟环境中复现论文(环境配置)
  • 力扣 hot100 Day46
  • 01 启动流程实例
  • 基于docker的redis集群
  • 开源 python 应用 开发(七)数据可视化
  • 基于大数据电信诈骗行为分析与可视化预测系统的设计与实现【海量数据、多种机器学习对比、数据优化、过采样】
  • 软路由 + 代理 IP 实现多手机不同公网 IP 分配教程
  • 60个功能OfficeBox 万彩办公大师:PDF 格式转换 OCR识别免费无广告
  • 【数据结构】栈与链表的区别
  • 物联网CAN通讯(控制器局域网络)(寄存器版+HAL库版)
  • 分布式缓存击穿以及本地击穿解决方案
  • xss-labs练习
  • 「源力觉醒 创作者计划」_巅峰对话:文心大模型4.5系列与DeepSeek/Qwen 3.0深度解析
  • React -自定义hooks - 封装双向数据绑定
  • 【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts) 视频教程 - 微博类别信息爬取
  • 在 Spring Boot 中监控异步任务的执行情况
  • Flask 项目结构
  • Flask的基本概念
  • Ray集群部署与维护
  • 显示器如何突破 DisplayPort 1.4 的带宽限制,显示更高的分辨率刷新率
  • 网络劫持对用户隐私安全有何影响?
  • python fonttools字体多语言解析
  • iOS 上架被拒 4.3a 【Cocos全面解读】
  • iOS App 上架流程优化指南 工具组合与常见问题处理经验总结
  • 用AI做带货视频评论分析进阶提分【Datawhale AI 夏令营】