LeetCode 分类刷题:1669. 合并两个链表

题目

给你两个链表 list1list2 ,它们包含的元素分别为 n 个和 m 个。

请你将 list1 中下标从 ab 的全部节点都删除,并将list2 接在被删除节点的位置。

下图中蓝色边和节点展示了操作后的结果:

请你返回结果链表的头指针。

提示:

  • 3 <= list1.length <=
  • 1 <= a <= b < list1.length - 1
  • 1 <= list2.length <=

解析

我的思路:

// 第一次快指针从头走(b-a+2)步

// 第二次快指针继续走a-1步,慢指针从头走a-1步

// 修改快慢指针分别指向链表2的尾和头

官方题解思路:

// 第一次慢指针从头走a-1步

// 让快指针指向慢指针的位置,再走(b-a+2)步

// 慢指针的next指向list2(头节点)

// list2移动到链表2的尾节点

// 快指针的next指向list2(尾节点)

对比可以发现官方题解有几处巧思,比如:直接让快指针指向慢指针再走(b-a+2)步;确定快慢指针的位置后,先让慢指针的下个节点链接上链表2,再将链表2的头指针用于移动,寻找尾节点,避免了创建新的指针变量。

答案

我的答案:

javascript 复制代码
/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
 * @param {ListNode} list1
 * @param {number} a
 * @param {number} b
 * @param {ListNode} list2
 * @return {ListNode}
 */
var mergeInBetween = function(list1, a, b, list2) {
    // 第一次快指针走(b-a+2)步
    // 第二次快指针走a-1步,慢指针走a-1步
    // 修改快慢指针分别指向链表2的尾和头
    let slow = list1;
    let fast = list1;
    for(let i = 0; i < b - a + 2; i++) {
        fast = fast.next;
    }
    for(let i = 0; i < a - 1; i++) {
        fast = fast.next;
        slow = slow.next;
    }
    let tail2 = list2;
    while(tail2.next) {
        tail2 = tail2.next;
    }
    slow.next = list2;
    tail2.next = fast;
    return list1;
};

官方题解:

javascript 复制代码
var mergeInBetween = function(list1, a, b, list2) {
    let preA = list1;
    for (let i = 0; i < a - 1; i++) {
        preA = preA.next;
    }
    let preB = preA;
    for (let i = 0; i < b - a + 2; i++) {
        preB = preB.next;
    }
    preA.next = list2;
    while (list2.next) {
        list2 = list2.next;
    }
    list2.next = preB;
    return list1;
};

// 作者:力扣官方题解
// 链接:https://leetcode.cn/problems/merge-in-between-linked-lists/solutions/2079499/he-bing-liang-ge-lian-biao-by-leetcode-s-alt8/
// 来源:力扣(LeetCode)
// 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

复杂度分析

时间复杂度:O(n+m),其中 n 是 list1​ 的长度,m 是 list2​ 的长度。

空间复杂度:O(1)

我觉得时间复杂度是O(b + m),但是官方题解给的是O(n+m)?

  • O(b + m):强调操作与b的直接关系。
  • O(n + m):强调最坏情况下与链表1长度的关系。

更规范的表述是O(n + m),因为算法分析通常以输入规模的完整上限为准。

相关推荐
珍珠是蚌的眼泪18 分钟前
LeetCode_二叉树1
leetcode·二叉树·层序遍历·前序遍历·中序遍历·后续遍历
●VON30 分钟前
React Native for OpenHarmony:构建高性能、高体验的 TextInput 输入表单
javascript·学习·react native·react.js·von
●VON35 分钟前
React Native for OpenHarmony:ActivityIndicator 动画实现详解
javascript·学习·react native·react.js·性能优化·openharmony
霍理迪42 分钟前
JS其他常用内置对象
开发语言·前端·javascript
老鼠只爱大米1 小时前
LeetCode经典算法面试题 #199:二叉树的右视图(BFS双队列法、DFS递归法等多种实现方案详细解析)
算法·leetcode·二叉树·dfs·bfs·深度优先搜索·右视图
历程里程碑1 小时前
子串-----和为 K 的子数组
java·数据结构·c++·python·算法·leetcode·tornado
We་ct1 小时前
LeetCode 383. 赎金信:解题思路+代码解析+优化实战
前端·算法·leetcode·typescript
pusheng20252 小时前
普晟传感2026年新春年会总结与分析
前端·javascript·html
谢尔登2 小时前
React19事件调度的设计思路
前端·javascript·react.js
一匹电信狗2 小时前
【高阶数据结构】并查集
c语言·数据结构·c++·算法·leetcode·排序算法·visual studio