23. 合并 K 个升序链表(难)

news/2025/1/10 11:08:49/文章来源:https://www.cnblogs.com/lushuang55/p/18663617

目录
  • 题目
  • 法一:暴力
  • 法二:递归+分治
  • 法三、找最小

题目

  • 给你一个链表数组,每个链表都已经按升序排列。
    请你将所有链表合并到一个升序链表中,返回合并后的链表。

示例 1:

输入:lists = [[1,4,5],[1,3,4],[2,6]]
输出:[1,1,2,3,4,4,5,6]
解释:链表数组如下:
[
1->4->5,
1->3->4,
2->6
]
将它们合并到一个有序链表中得到。
1->1->2->3->4->4->5->6

示例 2:

输入:lists = [[]]
输出:[]

法一:暴力

  • 先合并前两个链表,再把得到的新链表和第三个链表合并,再和第四个链表合并,依此类推
// 21. 合并两个有序链表
var mergeTwoLists = function (list1, list2) {const dummy = new ListNode(); // 哨兵节点let cur = dummy; // 指向新链表的末尾while (list1 && list2) {if (list1.val < list2.val) {cur.next = list1; // 添加 list1 的当前节点list1 = list1.next; // 移动 list1} else {cur.next = list2; // 添加 list2 的当前节点list2 = list2.next; // 移动 list2}cur = cur.next; // 更新新链表的末尾}cur.next = list1 ? list1 : list2; // 拼接剩余的链表return dummy.next; // 返回合并后的链表头节点
};var mergeKLists = function (lists) {if (lists.length === 0) return null; // 如果没有链表,返回 nulllet mergedList = lists[0]; // 从第一个链表开始// 逐个合并其他链表for (let i = 1; i < lists.length; i++) {mergedList = mergeTwoLists(mergedList, lists[i]);}return mergedList; // 返回最终合并后的链表
};

法二:递归+分治

  • 把 lists 一分为二,先合并前一半的链表,再合并后一半的链表,然后把这两个链表合并成最终的链表。如何合并前一半的链表呢?我们可以继续一分为二。如此分下去直到只有一个链表,此时无需合并。
// 21. 合并两个有序链表
var mergeTwoLists = function (list1, list2) {const dummy = new ListNode(); // 用哨兵节点简化代码逻辑let cur = dummy; // cur 指向新链表的末尾while (list1 && list2) {if (list1.val < list2.val) {cur.next = list1; // 把 list1 加到新链表中list1 = list1.next;} else { // 注:相等的情况加哪个节点都是可以的cur.next = list2; // 把 list2 加到新链表中list2 = list2.next;}cur = cur.next;}cur.next = list1 ? list1 : list2; // 拼接剩余链表return dummy.next;
};var mergeKLists = function (lists) {// 合并从 lists[i] 到 lists[j-1] 的链表function dfs(i, j) {const m = j - i;if (m === 0) {return null; // 注意输入的 lists 可能是空的}if (m === 1) {return lists[i]; // 无需合并,直接返回}//Math.floor(m / 2)与(m >> 1)等价const left = dfs(i, i + Math.floor(m / 2)); // 合并左半部分const right = dfs(i + (m >> 1), j); // 合并右半部分return mergeTwoLists(left, right); // 最后把左半和右半合并}return dfs(0, lists.length);
};

法三、找最小

  • 因为子链表都是升序,每次的最小值一定在子链表的头节点。
var mergeKLists = function(lists) {// 创建一个新的链表头const mergedHead = new ListNode(0);let current = mergedHead;while (true) {let minIndex = -1;//最小下标let minValue = Infinity;//最小值// 找到当前所有链表中最小的节点for (let i = 0; i < lists.length; i++) {//一开始lists[i].val是lists中子链表的头节点if (lists[i] && lists[i].val < minValue) {minValue = lists[i].val;minIndex = i;}}// 如果找到了最小节点,则将其添加到合并链表中if (minIndex !== -1) {current.next = lists[minIndex];current = current.next;lists[minIndex] = lists[minIndex].next; // 在该子链表中移动到下一个节点} else {// 如果没有找到最小节点,说明所有链表都已合并break;}}return mergedHead.next; // 返回合并后的链表头
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/867065.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RapidTable release v1.0.3

引言 经过几日来的不懈努力,RapidTable 库终于迎来了 1.0 系列。 RapidTable 库是专门用来文档类图像的表格结构还原,表格结构模型均属于序列预测方法,结合 RapidOCR,将给定图像中的表格转化对应的 HTML 格式。 效果展示模型列表model_type 模型名称 推理框架 模型大小 推理…

ur3+robotiq ft sensor+robotiq 2f 140配置rviz仿真环境-

原文地址: ur3+robotiq ft sensor+robotiq 2f 140配置rviz仿真环境 ur3+robotiq ft sensor+robotiq 2f 140配置rviz仿真环境搭建环境: ubuntu: 20.04ros: Noneticsensor: robotiq_ft300gripper: robotiq_2f_140_gripperUR: UR3 在安装sensor和gripper之前,先简单配置一下UR机…

【Python】简单实现Http网络请求功能

1.安装uvicorn和FastAPI pip3 install uvicorn pip3 install FastAPI2.python代码实现 import uvicorn from fastapi import FastAPIapp = FastAPI() @app.post("/ShowNum") async def ShowNum(x:int=1,y:int=2):print(和为:%d % (x+y))return x+yif __name__ == &q…

JMeter自动执行生成报告,批处理脚本

1、新建文件后缀.bat: 字符集使用 ANSI 编码,不然有中文会乱码,执行失败2、输入内容如下,根据实际情况修改路径:@echo off REM 设置 JMeter 的安装目录,根据实际情况修改路径 set JMETER_HOME=C:\apache-jmeter-5.4.1 REM 设置测试计划的路径,根据实际情况修改路径 set T…

奇迹mu1.03单机版安装教程+无需虚拟机+GM工具

今天为大家带来一款怀旧网单《奇迹mu1.03》的游戏架设,适用于单机娱乐, 仅供怀旧,本人已经安装游戏成功,特此带来详细安装教程。 适用环境单机视频演示 https://githubs.xyz/show/330.mp4亲测截图 架设步骤 关闭默认杀毒软件和其它自己下的杀毒软件 ,一定要检查关闭!!…

Toeplitz矩阵

具有下面形式的矩阵称为 Toeplitz 矩阵 (即在同一条对角线上的元素都相等) • Toeplitz 矩阵只有 2n − 1 个独立元素, 因此在存储一个 Toepliz 矩阵时, 只需存储第一列和第一行 (或第一列和最后一列);• 如果 T 对称, 则只需存储第一列. 用途:

【转载】【cursor】解决 cursor IDE 不能正常给 python 代码高亮的问题

原文链接:How to use python with the Cursor IDE首先参照上面的解决方法进行配置,配置完成后若不生效,请检查:1. 在 cursor 中把本地和远程的 python 扩展设置都进行以下修改 2. 若修改后不生效,重启 python 插件(看不明白的话请留言)

2025 年,程序员如何找准技术“掘金点”?

大家好,我是 V 哥,最近有很多小伙伴来问V哥,悲催的2024终于过去了,有的早早就给自己放假等春节了,有的也没逃过临了被约喝咖啡☕️,都想着先过完年再考虑怎么办,躺平可不行,又有谁会跟钱过不支呢。2025 年,V 哥也跟一些行业大佬聊过,共同的一个点就是市场经济依然不会…

基于ODX的工程诊断仪 - DST.Tester

INTEWORK-DST(Tester Option,以下简称DST.Tester)是经纬恒润自主研发的工程诊断仪,适用于新车型和ECU的诊断和刷写。DST.Tester不仅支持多种ISO协议,也可以按照客户需求开发刷写流程,满足整车厂和零部件供应商的诊断工程师使用需求。概述INTEWORK-DST(Tester Option,以下简…

JS-25 字符串方法_indexOF()

indexOf方法用于确定一个字符串再另一个字符串中第一次出现的位置,返回结果是匹配开始的位置。如果返回-1,就表示不匹配 hello world.indexOf(o)//4 hello world.indexOf(a)//4-1 床前明月光,疑是地上霜。一去二三里,举头望明月,低头思故乡。.indexOf("一去二三里&qu…

点特征直方图

对点特征的描述常见的描述手段有,曲率、法线等,由于点云散乱无序形态各异,即使人眼是判别特征与非特征点都极其困难,所以仅仅凭借曲率、法线来对点云特征进行描述,显然是不够的。那如何准确或者全面的去描述点的特征呢,这也是很多算法的基石,特征描述准确与否直接会影响…