返回介绍

solution / 1600-1699 / 1669.Merge In Between Linked Lists / README

发布于 2024-06-17 01:03:15 字数 5992 浏览 0 评论 0 收藏 0

1669. 合并两个链表

English Version

题目描述

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

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

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

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

 

示例 1:

输入:list1 = [10,1,13,6,9,5], a = 3, b = 4, list2 = [1000000,1000001,1000002]
输出:[10,1,13,1000000,1000001,1000002,5]
解释:我们删除 list1 中下标为 3 和 4 的两个节点,并将 list2 接在该位置。上图中蓝色的边和节点为答案链表。

示例 2:

输入:list1 = [0,1,2,3,4,5,6], a = 2, b = 5, list2 = [1000000,1000001,1000002,1000003,1000004]
输出:[0,1,1000000,1000001,1000002,1000003,1000004,6]
解释:上图中蓝色的边和节点为答案链表。

 

提示:

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

解法

方法一:模拟

直接模拟题目中的操作即可。

在实现上,我们使用两个指针 $p$ 和 $q$,初始时均指向链表 list1 的头节点。

然后我们向后移动指针 $p$ 和 $q$,直到指针 $p$ 指向链表 list1 中第 $a$ 个节点的前一个节点,指针 $q$ 指向链表 list1 中第 $b$ 个节点。此时我们将 $p$ 的 next 指针指向链表 list2 的头节点,将链表 list2 的尾节点的 next 指针指向 $q$ 的 next 指针指向的节点,即可完成题目要求。

时间复杂度 $O(m + n)$,空间复杂度 $O(1)$。其中 $m$ 和 $n$ 分别为链表 list1list2 的长度。

# Definition for singly-linked list.
# class ListNode:
#   def __init__(self, val=0, next=None):
#     self.val = val
#     self.next = next
class Solution:
  def mergeInBetween(
    self, list1: ListNode, a: int, b: int, list2: ListNode
  ) -> ListNode:
    p = q = list1
    for _ in range(a - 1):
      p = p.next
    for _ in range(b):
      q = q.next
    p.next = list2
    while p.next:
      p = p.next
    p.next = q.next
    q.next = None
    return list1
/**
 * 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 mergeInBetween(ListNode list1, int a, int b, ListNode list2) {
    ListNode p = list1, q = list1;
    while (--a > 0) {
      p = p.next;
    }
    while (b-- > 0) {
      q = q.next;
    }
    p.next = list2;
    while (p.next != null) {
      p = p.next;
    }
    p.next = q.next;
    q.next = null;
    return list1;
  }
}
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *   int val;
 *   ListNode *next;
 *   ListNode() : val(0), next(nullptr) {}
 *   ListNode(int x) : val(x), next(nullptr) {}
 *   ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
  ListNode* mergeInBetween(ListNode* list1, int a, int b, ListNode* list2) {
    auto p = list1, q = list1;
    while (--a) {
      p = p->next;
    }
    while (b--) {
      q = q->next;
    }
    p->next = list2;
    while (p->next) {
      p = p->next;
    }
    p->next = q->next;
    q->next = nullptr;
    return list1;
  }
};
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *   Val int
 *   Next *ListNode
 * }
 */
func mergeInBetween(list1 *ListNode, a int, b int, list2 *ListNode) *ListNode {
  p, q := list1, list1
  for ; a > 1; a-- {
    p = p.Next
  }
  for ; b > 0; b-- {
    q = q.Next
  }
  p.Next = list2
  for p.Next != nil {
    p = p.Next
  }
  p.Next = q.Next
  q.Next = nil
  return list1
}
/**
 * Definition for singly-linked list.
 * class ListNode {
 *   val: number
 *   next: ListNode | null
 *   constructor(val?: number, next?: ListNode | null) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 *   }
 * }
 */

function mergeInBetween(
  list1: ListNode | null,
  a: number,
  b: number,
  list2: ListNode | null,
): ListNode | null {
  let p = list1;
  let q = list1;
  while (--a > 0) {
    p = p.next;
  }
  while (b-- > 0) {
    q = q.next;
  }
  p.next = list2;
  while (p.next) {
    p = p.next;
  }
  p.next = q.next;
  q.next = null;
  return list1;
}
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *   public int val;
 *   public ListNode next;
 *   public ListNode(int val=0, ListNode next=null) {
 *     this.val = val;
 *     this.next = next;
 *   }
 * }
 */
public class Solution {
  public ListNode MergeInBetween(ListNode list1, int a, int b, ListNode list2) {
    ListNode p = list1, q = list1;
    while (--a > 0) {
      p = p.next;
    }
    while (b-- > 0) {
      q = q.next;
    }
    p.next = list2;
    while (p.next != null) {
      p = p.next;
    }
    p.next = q.next;
    q.next = null;
    return list1;
  }
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文